- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
看看第一个场景,您有一个包含 2 列的表 - Parent (P) 和 Child (C)。
P-C1-32-83-66-48-7
When users search for all descendants of "1" then it will show:
P-C1-33-66-4
& When users search for all descendants of "2" then it will show:
P-C2-88-7
This is the Mysql query to get the Data
select distinct col1
from (select col1,
@pv:=(case when find_in_set(col2, @pv) then @pv else concat(@pv, ',', col2)
end) as 'col2'
from table1 join
(select @pv:='1') tmp
on find_in_set(col1, @pv) > 0
) t
Ok,你知道Database indexing就是对column进行索引,这样DB查询DB的速度比没有indexing的时候要快。
但是,在上面提到的第一种情况下,“您认为数据库索引在父子表中扮演重要角色吗?”
好的,如果用户搜索“2”的所有后代,那么数据库首先找到“2-8”,然后它必须跳过 2 个记录才能找到下一个子“8-7”。
这是一个简单的例子,但是如果有成千上万的记录彼此相距很远(或者数据的位置非常零散),那么“DB(假设父子列已建立索引)如何能够场景一快速查资料?”
但是如果我们让所有的后代像第二种情况一样坐在一起:
P-C1-33-66-42-88-7
然后“数据库(即使我们不索引父子列)在第二种情况下查找数据的速度会比第一种情况快吗?”
注意:如果像这样颠倒后代的顺序:
P-C6-43-61-32-88-7
& 如果您搜索“1”,那么它只会显示“3”,不会显示“3-6”和“6-4”,因为“3-6”和“6-4”不是在连续的顺序中。这意味着MYSQL在运行上述查询时,会从上到下查找记录。所以这意味着Mysql不会从头开始寻找下一个后代,->你认为是这样吗?
注意:请同时阅读此链接 @ Symbol - a solution for Recursive SELECT query in Mysql?
最佳答案
使用您的数据
P-C
1-3
3-6
6-4
2-8
8-7
MySQL会找到5条记录,假设选择按这个顺序返回(可以按照今天Oracle食堂菜单上的1、3、6、2、8的价格顺序返回) :-
第一条记录是1,它会将3(即 child )存入变量pv中。然后它将获得下一条记录。这是记录 3,它将查看它是否存储在 pv 中并找到它,6 将连接到 pv 的末尾。然后它将获取下一条记录(在本例中为 6),检查 6 是否存储在 pv 中,并将 4 连接到 pv 的末尾。然后它将获取下一条记录(在本例中为 2),检查 2 是否存储在 pv 中,但如果没有,它将忽略它。然后它将获取下一条记录(在本例中为 8),检查 8 是否存储在 pv 中,但如果没有,它将忽略它。
无论您是否需要,它都会继续处理表中的每条记录。它不会使用任何索引来执行任何这些检查,或者在它到达所有记录的末尾之前停止处理。
MySQL(以及一般的关系数据库)旨在获取数据集,并且非常适合将一组数据与另一组数据进行比较。上面的查询正在获取一组数据(可能非常大)并以随机顺序(您希望这是您输入它们的顺序)遍历每个返回的记录,并根据它正在构建的变量检查每个记录。
关于mysql - 数据库索引在父子表中扮演重要角色吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16709112/
什么是事物 事务是一种机制、一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这组数据库命令要么都执行,要么都不执行。 事务是一个不可分割的工.作逻辑
什么是范式? 简言之就是,数据库设计对数据的存储性能,还有开发人员对数据的操作都有莫大的关系。所以建立科学的,规范的数据库是需要满足一些规范来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范
什么是事物 事务是一种机制、一个操作序列,包含了一组数据库操作命令,并且把所有的命令作为一个整体一起向系统提交或撤销操作请求,即这组数据库命令要么都执行,要么都不执行。 事务是一个不可分割的工.作逻辑
什么是范式? 简言之就是,数据库设计对数据的存储性能,还有开发人员对数据的操作都有莫大的关系。所以建立科学的,规范的数据库是需要满足一些规范来优化数据数据存储方式。在关系型数据库中这些规范就可以称为范
我正在尝试修改网站的布局,但有时网站会使用 !important,有没有办法覆盖它?我似乎无法弄清楚如何在页面的 css 文件之后加载 css 内容脚本。 最佳答案 !important CSS 规则
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 9 年前。 我写了一些 html,并在第三方网站中注入(inject)了一些 css 样
好的,我在这里安装了一个 wordpress 主题(www.sullivansuccesscoaching.com/home ...我们需要/home,因为仍然有一个 index.html 隐藏了 w
我已经为我的 Wordpress 模板创建了一个覆盖原始 CSS 的自定义样式表。但是,在我的日历页面上,原始 CSS 具有使用 !important 声明设置的每个表格单元格的高度: td {hei
这个问题在这里已经有了答案: How to document deconstructed parameters with JsDoc (1 个回答) 关闭 5 年前。 我正在努力寻找对文档 ES6
我的网站使用 bootstrap 4 和我制作的 css 文件。 在这个 css 文件的底部,我放置了一些媒体查询: @media (max-width: 575px) { .address .c
可以将 background-position X 设置为 0 带有标志 !important 和背景位置 Y 不带 !important? 例如: background-position-x: 0
我只想在焦点状态下去掉下拉列表中的轮廓。看这张图 我尝试使用 !important 覆盖 Bootstrap ,但根本不起作用。只是检查开发工具,突然看到这个。 Bootstrap 也使用 !impo
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 1 年前。
发生了什么事?:我的 jQuery Accordion 的动画坏了。在关闭上一个选项卡之前短时间单击下一个选项卡后,它会显示之前打开的选项卡。动画也不滑动。 CSS:来自this answer /*
如何使用 javascript 或 CSS 覆盖样式“color: red”?我想让它成为“2px”而不是“1px”边框。 Lorem... 我无法向“div”添加类、id。这不
这个问题在这里已经有了答案: How to override !important? (12 个答案) 关闭 5 年前。
滚动有问题不想显示其内容,如果我这样做 #callCenter { position: fixed; z-index: 2411 !important; display: bl
序言 1、MySQL表操作(创建表,查询表结构,更改表字段等), 2、MySQL的数据类型(CHAR、VARCHAR、BLOB,等), 本节比较重要,对数据表数据进行查询操作,其中可能大
如何将!important添加到客户端包GWT中的gwt-image: 我有这个: @sprite .superButton{ gwt-image : 'superButton'; backg
请帮助我..我想验证表单并使用 ajax 发送。 验证没有 ''onsubmit="return validateForm(this);"'' 工作。 但是当表单正确时,它的发送表单(页面刷新..)请
我是一名优秀的程序员,十分优秀!