- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个选择菜单,用户可以在其中选择特定功能,并且根据他们的选择,会显示一个包含新选项的新选择菜单。根据他们的选择,这个过程可以重复多次。
例如,如果选择菜单显示这些项目:apple、mango、orange。
然后用户选择 apple
:他们将获得三个与苹果相关的附加选项 - brown、red、green。
如果用户选择 orange
例如,他们可能会看到 红色、橙色。
请注意,红色出现了两次。
我的主要问题是找到一种追踪它的好方法。
我有两个表 - features
和 feature_group。
feature_group
包含列:id
、name
features
包含列:id
、group_id
、name
、links
如果我们回到前面的例子,
我目前将选项存储在 links
部分。
feature_group
表:
| id | name |
|----|--------|
| 1 | Fruit |
| 2 | Colour |
| 3 | Taste |
特征
表:
| id | group_id | name | links |
|----|----------|--------|-----------|
| 1 | 1 | Apple | |
| 2 | 1 | Mango | |
| 3 | 1 | Orange | |
| 4 | 2 | Red | 1,2,3 |
| 5 | 2 | Green | 1,2 |
| 6 | 2 | Orange | 3 |
| 7 | 3 | Slicy | 1,2;1,2,3 |
| 8 | 3 | Okay | 1,2,3,4 |
| 9 | 3 | Bad | 2,4 |
如您所见,links
列包含same 表中features
的id
。因此,例如,当用户选择任何选项 Apple、Mango、Orange 时,名称为
Red
的第 4 行是可见的。
同样,如果他们不能选择 Bad
作为第三个选项,如果他们为第一个选项选择了 Mango
和 Red
以外的任何选项第二个选项。
;
也用于包含其他选项对。
我希望这是有道理的。
这是我的表结构。在代码中,我将它作为一个数组来做:
$color = [
'Apple' => [
'Red',
'Green',
],
'Mange' => [
'Red',
'Green',
],
'Orange' => [
'Red',
'Orange',
],
];
$taste = [
'Red' => [
'Slicy'
],
// so on...
];
我认为这不是最好的方法。特别是如果我以后想添加更多的东西,那么我必须修改我的数据很多,这会很麻烦。
如何解决这个问题?
最佳答案
由于您想自由地尽可能深入,因此可以使用以下解决方案:
Table: features
| id | name |
|----|-------|
| 1 | Apple |
| 2 | Red |
| 3 | Green |
| 4 | Sweet |
| 5 | Sour |
| 6 | Cake |
| 7 | Cider |
Table: feature_parent_child // maybe you have a better name
| parent_id | child_id |
|-----------|----------|
| 1 | 2 |
| 1 | 3 |
| 2 | 4 |
| 3 | 5 |
| 4 | 6 |
| 5 | 7 |
如果我们遵循我们的关系,我们最终会得到:
Apple -> Red -> Sweet -> Cake -> ...
Apple -> Green -> Sour -> Cider -> ...
这样我们就可以想深入就深入。我们也可以将其他特征的子特征作为“根”特征:
Cake -> Sugar -> Sweet -> Apple
Cider -> Party -> Happy -> Cake -> Birthday
困难在于管理特征的数量。
评论后更新
由于关卡深度无限,一次加载所有选项并不明智。因此,我们被迫通过执行单独的请求来加载下一个功能。
首先,我们可以返回给定特征的所有子元素:
id 1
。id 1
的所有子项,响应 [2, 3]
。id 2
。id 2
的所有子项,响应 [4]
。我认为,如果我弄错了,请原谅,也可以根据其先前的 parent 为每个特征赋予不同的 child 。然而,这需要更多的逻辑。
例子:
Apple -> Red
Apple -> Green
Red -> Apple -> Tasty
Red -> Apple -> Cake
我们可以看到 Apple
有两个子特征 Red
和 Green
。然而,一旦我们将 Red
作为父级,我们就可以看到 Apple
有两个不同的功能,Tasty
和 Cake
。需要执行以下程序。
红色
。Red
为父级的特征。在给定的示例中是 Apple
。Apple
。Apple
为父级且 Apple
以 Red
为父级的对象。分别是 Tast
和 Cake
。关于php - Laravel - 在数据库中存储动态选项的问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55997340/
给定一个 Option[Future[Option[Int]]] : scala> val x: Option[Future[Option[Int]]] = Some ( Future ( Some
如果我理解正确,EitherT[Option,A,B] 应该与 Option[Either[A,B]] 相同,但编译器不同意.以下代码编译失败: def f[A,B] = implicitly[Eit
我刚开始在使用 parcel.js 构建静态 Assets 时遇到此错误。它在本地工作,但我在 Heroku 上的构建出错,我不确定它是否相关。 最佳答案 得到同样的问题。通过将 core-js 安装
当我生成 Telerik Report 时,只有 Export PDF 可用。即使我将 docx 和 xlsx 的配置设置为 true。这是我在网络配置中的配置。
我的 iTunesConnect 应用程序显示 Apple Pay 选项。我正在使用布伦特里。 即使我们没有在应用程序中使用 Apple Pay 功能。 有人可以帮我解决如何在我的 itunesCon
我正在 Raspbian 中从命令行运行以下查询: mysql -u $NAME -p $PASS Tweets -e "SELECT count(*) FROM raw_tweets;" 它输出以下
我正在尝试使用 ffmpeg(在 linux 下)为视频添加一个小标题。所以,我使用: ffmpeg -i hk.avi -r 30000/1001 -metadata title="SOF" hk_
我正在尝试使用 ffmpeg 使用 ffserver 流式传输视频。您将在 ffserver1.conf 文件下方找到 ffmpeg 命令的日志输出。 其中一个错误引用了预设,每次我尝试使用预设时,我
我正在尝试对 Option 使用 fold 或 map 操作而不是 match。 我有一个选项 val ao: Option[String] = xxxx 和一个函数 f: (String => Fu
Dockerfile documentation表示有可能通过 --platform FROM 中的选项像这样的指令: FROM [--platform=] [AS ] 在我的 dockerfile
我不确定“属性(property)”或“选项”是否是正确的术语,但这是我需要弄清楚的。 鉴于以下情况: ' $.fileup({ url: '/file/upload',
我正在尝试使用 jQuery 检查是否选择了值 = 1 的选择选项,然后将类添加到某些元素。但有些东西不起作用。可以请人看一下代码吗? 我的代码: Reservation
我对 VIM 中的这些感到困惑。有些事情需要设置,而另一些则让。 而且,我如何检查某个选项。我知道这是一个选项,因为我使用 set 来更改它。 例如,如何检查当前文件类型选项是否为 java? 最佳答
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
我在看《Professional F# 2.0》一书作者展示如下代码 let a string : option = None if a.IsNone then System.Console.
我习惯使用方法顶部的 java 样板检查输入参数: public static Boolean filesExist(String file1, String file2, String file3
假设我有一串 "Insert Post -title Some PostTitle -category 2 -date-posted 2013-02:02 10:10:10" 我一直在尝试做的是将这个
从 1.3.70 EAP 开始,在 org.jetbrains.kotlin.gradle.dsl.KotlinJvmOptions 这是 var useIR: kotlin.Boolean 哪个激活
我无法获取订购捆绑商品的所有子产品及其选项。这可能吗? 最佳答案 以下是您如何找出哪些产品应与所有其他项目一起附加到列表中的捆绑产品中的方法: foreach ($order->getAllItems
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我是一名优秀的程序员,十分优秀!