- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个疑问:
SELECT DISTINCT field1 FROM table1 WHERE field2 = something
(table1包含100万条记录,执行时间:0.106秒,返回:20条记录)
另一个查询
SELECT DISTINCT similarField1 FROM table2 WHERE similarField2 = somethingElse
(table2包含50万条记录,执行时间:0.078秒,返回:20条记录)
现在,如果我通过组合以上两者来运行查询:
SELECT DISTINCT field1 FROM table1 WHERE field2 = something AND field1 NOT IN (SELECT DISTINCT similarField1 FROM table2 WHERE similarField2 = somethingElse)
即使运行 10 分钟也没有给出结果。为什么它变得非常慢,以及可能的解决方案是什么。
编辑:我正在将 MySQL 与 dbvisualizer 6.5 一起使用
最佳答案
您不需要在子查询上使用DISTINCT
。尝试使用 NOT EXISTS
这在 SQL-Server 中可能更有效:
SELECT DISTINCT field1
FROM table1
WHERE field2 = @something
AND NOT EXISTS
(
SELECT 1 FROM table2
WHERE table2.similarfield1 = table1.field2
AND table2.similarfield2 = @somethingelse
)
编辑:由于您已经更新了标签,我不确定这在 MySql 中是否更有效。但是,无论如何,我更喜欢NOT EXISTS
,因为它也works with NULL
values (如果您使用IS NULL
)并且更易于阅读和维护。
关于mysql - 为什么在查询中使用 IN(或 NOT IN)子句会使查询变得非常慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28407296/
我在 android 代码中使用 asmack XMPP。我可以正常登录 XMPP 服务器,但是当我尝试创建新用户时出现问题。我想要实现的是: 以管理员身份登录。 创建一个新用户。 从管理员注销。 以
这是我的标记页面,其中有一个按钮可以从数据库中搜索数据并显示在网格中 这是我背后的代码 if (!IsPostBack) { LblInfo.Text = "Page Load
当我多次将相同的 float 值插入到我的集合中时,本应花费恒定时间的 x in s 检查变得非常慢。为什么? 时序x in s的输出: 0.06 microseconds 0.09 mi
我有一个小型聊天客户端,可以将所有历史记录存储在 sqlite 数据库中。当用户单击我的应用程序中的 history 选项卡时,我的应用程序会获取所有相关历史记录并将其显示在 QWebView 中。我
我是一名优秀的程序员,十分优秀!