- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 3 个表,如下所示:
解析表(table1)
+----+---------+-----+------------+--------+
| id | created | num | resolution | score |
+----+---------+-----+------------+--------+
作者表(table2)
+----+---------+--------+------+------+--------+
| id | created | author | file | tags | res_id |
+----+---------+--------+------+------+--------+
状态表(table3)
+----+------+-------------+----------+--------+-----------+
| id | name | description | category | status | author_id |
+----+------+-------------+----------+--------+-----------+
我正在使用 2 个 select 语句根据它们的 ID 从同一个表中获取记录,如下所示:
语句 1(分辨率 num = 1357)
select *
from table1, table2, table3
where table1.num=1357
and table1.id=table2.res_id
and table2.id=table3.author_id;
语句 2(分辨率 num = 1358)
select *
from table1, table2, table3
where table1.num=1358
and table1.id=table2.res_id
and table2.id=table3.author_id;
注意:每个语句返回 100,000 多条记录
我使用右外连接来获取 statement2 中不存在于 statement1 结果中的记录,如下所示:
select * from (
select *
from table1, table2, table3
where table1.num=1357
and table1.id=table2.res_id
and table2.id=table3.author_id
) as tab1
right outer join (
select *
from table1, table2, table3
where table1.num=1358
and table1.id=table2.res_id
and table2.id=table3.author_id
) as tab2 on tab1.name=tab2.name
and tab1.category=tab2.category
and tab1.author=tab2.author
where tab1.name is NULL
and tab1.category is NULL
and tab1.author is NULL
这适用于少量记录,但在我的情况下,总共有 200,000 条记录,通常需要 11 分钟才能返回所需结果。
如何优化查询以更快地获取结果?
附言:
对table1.num、table2.res_id、table3.author_id应用索引后
show create table table1;
CREATE TABLE `table1` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`created` datetime NOT NULL,
`num` int(11) NOT NULL,
`resolution` varchar(100) NOT NULL,
`score` int(11) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `num` (`num`)
KEY `num_index` (`num`)
) ENGINE=InnoDB AUTO_INCREMENT=2552 DEFAULT CHARSET=latin1
show create table table2;
CREATE TABLE `table2` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`created` datetime NOT NULL,
`author` varchar(200) NOT NULL,
`file` varchar(200) NOT NULL,
`tags` varchar(200) DEFAULT NULL,
`res_id` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `table2_res_id_48009073_fk_table1_id` (`res_id`),
KEY `res_id_index` (`res_id`),
CONSTRAINT `table2_res_id_48009073_fk_table1_id ` FOREIGN KEY (`res_id`) REFERENCES `table1` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=686972 DEFAULT CHARSET=latin1
show create table table3;
CREATE TABLE `table3` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(200) NOT NULL,
`description` longtext NOT NULL,
`category` varchar(200) NOT NULL,
`status` varchar(20) NOT NULL,
`author_id` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `table3_ffe73c23` (`author_id`),
KEY `author_id_index` (`author_id`)
CONSTRAINT `table3_id_e47d088c_fk_table2_id` FOREIGN KEY (`author_id`) REFERENCES `table2` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=12042452 DEFAULT CHARSET=latin1
explain <"full select query">
+------+----------------+-----------+---------+--------------------------------------------------------------------------------------+-------------------------------------------------------------+--------------+--------------+-------+------------------------------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+------+----------------+-----------+---------+--------------------------------------------------------------------------------------+-------------------------------------------------------------+--------------+--------------+-------+------------------------------------+
| 1 | SIMPLE | table1 | const | PRIMARY,num,num_index | num | 4 | const | 1 | Using index |
| 1 | SIMPLE | table2 | ref | PRIMARY,table2_res_id_48009073_fk_table1_id,res_id_index. | table2_res_id_48009073_fk_table1_id. | 4 | const | 7106 | |
| 1. | SIMPLE | table3 | ref | table3_ffe73c23,author_id_index | table3_ffe73c23 | 4 | t2.id | 9 | |
| 1 | SIMPLE | table1 | const | PRIMARY,num,num_index | num | 4 | const | 1 | Using where; Using index |
| 1 | SIMPLE | table2 | ref | PRIMARY, table2_res_id_48009073_fk_table1_id,res_id_index | table2_res_id_48009073_fk_table1_id. | 4 | t1.id. | 213 | Using where |
| 1 | SIMPLE | table3 | ref | table3_ffe73c23, author_id_index | table3_ffe73c23 | 4 | t2.id | 9 | Using where; Not exists |
+------+----------------+----------+----------+-------------------------------------------------------------------------------------+-------------------------------------------------------------+---------------+---------------+-------+-----------------------------------+
最佳答案
尝试以下重写的查询:
SELECT
table1.*,
table2.*,
table3.*
FROM table1
INNER JOIN table2
ON table2.res_id = table1.id
INNER JOIN table3
ON table3.author_id = table2.id
LEFT OUTER JOIN (
SELECT
table3.name,
table3.category,
table2.author
FROM table1
INNER JOIN table2
ON table2.res_id = table1.id
INNER JOIN table3
ON table3.author_id = table2.id
WHERE table1.num = 1357
) tab1
ON tab1.name = table3.name
AND tab1.category = table3.category
AND tab1.author = table2.author
WHERE table1.num = 1358
AND tab1.name IS NULL
单独的查询可能会显示出一些改进。如果改善不大,请尝试以下新指标:
table2: INDEX(res_id, author)
table3: INDEX(author_id, category, name)
然后报告结果。
注意:尝试查询时,确保运行两次并丢弃第一个结果,以便填充 InnoDB 缓冲区缓存。
关于具有多个 select 语句的 MySQL 右外连接非常慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57618529/
我想知道最终用户按下了什么,所以我使用了 getch() 。 如果用户按右,我可以获得0xE0 0x4D。 如果用户按下Ctrl+右,我可以获得0xE0 0x47。 如果用户按下Shift+右,我可以
我已经构建了一个应用程序来搜索我的位置。 这是代码 var map; var gdir; var geocoder = null; var addressMarker; function init
我想为我的元素设计布局 View 。布局 View 在左 Angular 和右 Angular (同一行)有一个图像,将有 2 行单词,一行在第 1 行,另一行在第 2 行。我该如何实现? It
我有一个很长的线性(分支不多)流程图,在 graphviz 中显示为要么太高而无法放在单个页面上,要么太宽(如果方向是从左到右) 是否有一种简单的方法可以让 graphviz 以从左到右,然后向下,然
我一直摸不着头脑,但运气不好。设计器有一个包含 3 栏的站点、两个侧边栏和一个主要内容区域。 专为桌面设计,左栏、主要内容、右栏。但是,在较小的设备上,我们希望首先堆叠主要内容。 所以通常情况下,你可
我想要从上到下和从左到右组织的 css block 。 为了更好地解释这是一张图片,其中包含我到目前为止所获得的内容以及我希望使用 CSS 实现的内容: 代码如下: HTML: 1 2 3 4 5
当我问this question时,答案之一(现已删除)建议Either类型对应Curry-Howard correspondence中的XOR而不是OR,因为它不能同时是Left和Right。 真相
如果一行中六个观察值中至少有三个是 != NA,我想计算该行的平均值。如果存在四个或更多 NA,则平均值应显示为 NA。 给出平均值的例子,忽略了 NA: require(dplyr) a % mut
我有一个由 9 列组成的数据框,其中包含一个因素 list 。每行可以填充所有 9 列(因为在该行中包含 9 个“事物”),但大多数没有(大多数有 3-4 个)。列也不是特定的,就像第 1 列和第 3
这是我第一次尝试使用 R 构建函数。基本上我的预期目标如下。 使用 RoogleVision 包与 Google Cloud Vision API 通信 函数遍历目录中的图片 从每张图片的 Googl
使用: mean (x, trim=0.05) 从分布的每一侧移除 2.5%,这对于对称的双尾数据来说很好。但是如果我有一个尾部或高度不对称的数据,我希望能够只删除分布的一侧。有没有这个功能,还是我自
我想保留重复的列,并删除唯一的列。这些列将具有相同的值,但名称不同。 x1 = rnorm(1:10) x2 = rnorm(1:10) x3 = x1 x4 = rnorm(1:10) x5 = x
是否可以使WPF工具栏中的元素的Right水平对齐方式正确? 我尝试将内部元素添加到Grid中,并将ColumnDefinition分配给Left / Right。我
datatable(head(iris)) 如何将我的列居中,使其位于我的列名称的正下方? 最佳答案 您可以使用options 下的columnDefs 自变量。将 className 设置为 dt-
我是 R 的新手,但我正在尝试在 R 中制作滑动窗口。 使用循环我可以像这样,但这变得非常低效。 results=c(1:7) letters=c("A","B","C","D","E","F","G
假设我有这个 .txt 文件: here is line 1 here is line 2 here is line 3 here is line 4 我想将此字符串粘贴到第 3 行和第 4 行之间:
假设我有这个 .txt 文件: here is line 1 here is line 2 here is line 3 here is line 4 我想将此字符串粘贴到第 3 行和第 4 行之间:
我想知道我的环境中有什么类型的对象。 我可以像这样显示谁在那里: ls() 但是运行类似的东西 sapply(ls(), class) (显然)不会告诉我们我们拥有什么类型(类)的对象(函数、数字、因
我想创建一个带有水平标签的树状图,但让叶子根据它们的高度悬挂,而不是仅仅下降到图的边缘。 例子: par(mfrow = c(1,2)) hc <- hclust(dist(USArrests), "
我的 CSS 中有一个元素,如下所示 .xyz{ position:absolute; left:50%; } 现在正如预期的那样,当我减小浏览器窗口的宽度时,这个元素向左移动
我是一名优秀的程序员,十分优秀!