- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到了“OR”运算符在 mysql 中未使用任何索引的典型性能问题:
SELECT sms.smsID, sms.phonenumber, sms.text, date, mbr.name, mbr.prename
FROM sms INNER JOIN (SELECT MAX(smsID) as smsID, phonenumber FROM sms
group by phonenumber) sms2 ON sms.phonenumber = sms2.phonenumber AND
sms.smsID = sms2.smsID
LEFT JOIN mbr ON mbr.telephone = sms.phonenumber OR mbr.mobilphone =
sms.phonenumber where sms.smsmodem = 'GSM1'
order by date desc LIMIT 0,50
查询应返回最近 50 条收到的短信,但每个电话号码仅返回一条。然后它应该将其与mbr表连接起来,以查找电话号码是否与mbr表中的人名相关联。无论如何,在 mbr 表中,电话号码可能位于“电话”或“手机”列中,因此我们必须对两者进行检查。 where 子句中的 OR 运算符使查询时间超过 20 秒,因为它没有使用 mbr.telephone 和 mbr.mobilephone 存在的索引。
找到的解决方案是执行如下所示的 LEFT JOIN 构造: SQL - left join with OR operator (MySQL)或像这样的 UNION 构造: MySql JOIN query with OR clause very slow
但这两种情况我都不能使用。左连接构造将返回四列,而不是仅两列:
SELECT sms.smsID, sms.phonenumber, sms.text, date, mbr.name,
mbr.prename, mbr2.name, mbr2.prename FROM sms INNER JOIN (SELECT
MAX(smsID) as smsID, phonenumber FROM sms group by phonenumber) sms2 ON
sms.phonenumber = sms2.phonenumber AND sms.smsID = sms2.smsID LEFT JOIN
mbr ON mbr.telephone = sms.phonenumber left join mbr as mbr2 ON
mbr2.mobilphone = sms.phonenumber where sms.smsmodem = 'GSM1' order by
date desc LIMIT 0,50
联合解决方案只会返回两列,但会返回每条收到的消息两次,一次包含发送者的名称,一次不包含(因为一个选择会在 mbr 中找到相应的行,而另一个则不会):
SELECT sms.smsID, sms.phonenumber, sms.text, date, mbr.name,
mbr.prename, mbr2.name, mbr2.prename FROM sms INNER JOIN (SELECT
MAX(smsID) as smsID, phonenumber FROM sms group by phonenumber) sms2 ON
sms.phonenumber = sms2.phonenumber AND sms.smsID = sms2.smsID LEFT JOIN
mbr ON mbr.telephone = sms.phonenumber where sms.smsmodem = 'GSM1'
UNION SELECT sms.smsID, sms.phonenumber, sms.text, date, mbr.name,
mbr.prename, mbr2.name, mbr2.prename FROM sms INNER JOIN (SELECT
MAX(smsID) as smsID, phonenumber FROM sms group by phonenumber) sms2 ON
sms.phonenumber = sms2.phonenumber AND sms.smsID = sms2.smsID LEFT JOIN
mbr ON mbr.mobilephone = sms.phonenumber where sms.smsmodem = 'GSM1'
order by date desc LIMIT 0,50
我有点想知道这些“OR”运算符问题在 2016 年仍然存在......
最佳答案
OR 低效率仍然存在,因为没有简单(或困难)的解决方案。即使内置解决方案看起来也很像 UNION
解决方法。
让我们从不同的角度来看一下解决方案。您似乎有“一个跨列展开的数组”。在这种情况下,它是一个简单的 2 元素数组,但它引起了麻烦。我指的是电话/手机号码。
考虑在主表中不包含任何此类数字,而是使用另一个数字表。它可能有 3 列:smsID、number 和 number_type(如果需要)。通过在 Numbers 表中进行一次查找,可以消除OR
。
由于查询似乎是“分组最大值”,我还将向您指出我的 blog有效的方法来做到这一点。
关于Mysql 缓慢 "OR"运算符,但联合或两个单独的联接似乎没有选择,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39896563/
是否有某种方法可以使用 JPA 或 Hibernate Crtiteria API 来表示这种 SQL?或者我应该将其作为 native 执行吗? SELECT A.X FROM (SELECT X,
在查询中, select id,name,feature,marks from (....) 我想删除其 id 在另一个 select 语句中存在的那些。 从 (...) 中选择 id 我是 sql
我想响应用户在 select 元素中选择一个项目。然而这个 jQuery: $('#platypusDropDown').select(function () { alert('You sel
这个问题在这里已经有了答案: SQL select only rows with max value on a column [duplicate] (27 个回答) 关闭8年前。 我正在学习 SQL
This question already has answers here: “Notice: Undefined variable”, “Notice: Undefined index”, and
我在 php 脚本中调用 SQL。有时“DE”中没有值,如果是这种情况我想从“EN”中获取值 应该是这样的,但不是这样的 IF (EXISTS (SELECT epf_application_deta
这可能是一个奇怪的问题,但不知道如何研究它。执行以下查询时: SELECT Foo.col1, Foo.col2, Foo.col3 FROM Foo INNER JOIN Bar ON
如何在使用 Camera.DestinationType.FILE_URI. 时在 phonegap camera API 中同时选择或拾取多个图像我能够一次只选择一张图像。我可以使用 this 在
这是一个纯粹的学术问题。这两个陈述实际上是否相同? IF EXISTS (SELECT TOP 1 1 FROM Table1) SELECT 1 ELSE SELECT 0 相对 IF EXIS
我使用 JSoup 来解析 HTML 响应。我有多个 Div 标签。我必须根据 ID 选择 Div 标签。 我的伪代码是这样的 Document divTag = Jsoup.connect(link
我正在处理一个具有多个选择框的表单。当用户从 selectbox1 中选择一个选项时,我需要 selectbox2 active 的另一个值。同样,当他选择 selectbox2 的另一个值时,我需要
Acme Inc. Christa Woods Charlotte Freeman Jeffrey Walton Ella Hubbard Se
我有一个login.html其中form定义如下: First Initial Plus Last Name : 我的do_authorize如下: "; pri
$.get( 'http://www.ufilme.ro/api/load/maron_online/470', function(data
我有一个下拉列表“磅”、“克”、“千克”和“盎司”。我想要这样一种情况,当我选择 gram 来执行一个函数时,当我在输入字段中输入一个值时,当我选择 pounds 时,我想要另一个函数来执行时我在输入
我有一个 GLSL 着色器,它从输入纹理的 channel 之一(例如 R)读取,然后写入输出纹理中的同一 channel 。该 channel 必须由用户选择。 我现在能想到的就是使用一个 int
我想根据下拉列表中的选定值生成输入文本框。 Options 2 3 4 5 就在这个选择框之后,一些输入字段应该按照选定的数字出现。 最佳答案 我建议您使用响应式(Reac
我是 SQL 新手,我想问一下如何根据首选项和分组选择条目。 +----------+----------+------+ | ENTRY_ID | ROUTE_ID | TYPE | +------
我有以下表结构: CREATE TABLE [dbo].[UTS_USERCLIENT_MAPPING_USER_LIST] ( [MAPPING_ID] [int] IDENTITY(1,1
我在移除不必要的床单时遇到了问题。我查看了不同的论坛并将不同的解决方案混合在一起。 此宏删除工作表(第一张工作表除外)。 Sub wrong() Dim sht As Object Applicati
我是一名优秀的程序员,十分优秀!