gpt4 book ai didi

mysql - 具有多个 OR 的 SQL 查询的优先级

转载 作者:可可西里 更新时间:2023-11-01 07:57:17 25 4
gpt4 key购买 nike

我有两列:name, surname(名字,姓氏)

在查询中,尝试全名(例如:史蒂夫·乔布斯),然后我将单词分成变量(在 php 中)并执行查询:

SELECT * FROM `usuarios` WHERE 
(`nome` REGEXP '$bt1 $bt2') OR
(`nome` REGEXP '$bt1') OR
(`sobrenome` REGEXP '$bt1') OR
(`sobrenome` REGEXP '$bt1 $bt2')

问题是结果的显示没有按照查询的顺序,然后返回:

Steve John
John Jobs
Steve Jobs

Steve Jobs 的情况下如何确定查询和返回的优先级?

最佳答案

试试这个:

          (SELECT '1' as sb, usuarios.* FROM usuarios WHERE nom` REGEXP '$bt1 $bt2')
UNION ALL (SELECT '2' as sb, usuarios.* FROM usuarios WHERE nome REGEXP '$bt1')
UNION ALL (SELECT '3' as sb, usuarios.* FROM usuarios WHERE sobrenome REGEXP '$bt1')
UNION ALL (SELECT '4' as sb, usuarios.* FROM usuarios WHERE sobrenome REGEXP '$bt1 $bt2')
ORDER BY sb

关于mysql - 具有多个 OR 的 SQL 查询的优先级,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7324083/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com