使用以下查询:
SELECT * FROM people WHERE name REGEXP(bob|robert)
我假设mysql将以相当随机的顺序扫描每一行,查找' bob‘或'robert’(而不是先扫描bob,然后再扫描robert),这样做对吗?
如果是这样的话,有没有办法让mysql在不执行两次单独查询的情况下,先将整个表与'bob‘匹配,然后再与'robert’匹配?
发布于 2013-07-09 13:37:41
SELECT * FROM people WHERE name REGEXP(bob|robert) order by name desc
这只是一个查询,并完成工作。
SGBD可以随心所欲地扫描数据,它不是在SQL中指定的,也不是随机的。
未指定的可以是随机的,但不是随机的。
发布于 2013-07-09 13:37:30
没有一种逻辑方法可以先将整个表与bob
匹配(为什么要这样做?)
不过,您可以对结果进行排序,但是如果表的基数很高,并且/或者name
不是键,则排序会很慢。
SELECT * FROM people WHERE name = 'bob' OR name = 'robert'
ORDER BY name = 'bob' DESC
https://stackoverflow.com/questions/17549472
复制相似问题