MySQL语句之or/and

在where中可以包含任意数目的and和or操作符,在没有任何其他符号的时候,例如括号,SQL会首先执行and条件,然后才执行or语句

eg.    select * from table from id=1 or id=2 and price>=10;

这条语句默认执行的是id=2并且price大于等于10的,或者是id=1。

如果加上括号:select * from table from (id=1 or id=2) and price>=10;

则这条语句执行的是id=1或id=2,并且price大于等于10。

回答: 在MySQL中,OR语句用于在WHERE子句中指定多个条件之一成立的情况。当同时有AND和OR操作符时,MySQL会优先处理AND操作符。为了明确处理顺序和消除歧义,建议使用括号来确定条件的处理顺序。例如,可以使用以下语句查询满足条件的记录:SELECT * FROM products WHERE (products.vend_id=1002 OR products.vend_id=1003) AND prod_price >= 10; \[2\] 需要注意的是,在带有OR条件的WHERE语句中,MyISAM表可以使用索引,而InnoDB表则不行。如果你使用的是MyISAM表,可以创建一个示例表来演示,如下所示: CREATE TABLE IF NOT EXISTS a ( id int(1) NOT NULL AUTO_INCREMENT, uid int(11) NOT NULL, aNum char(20) DEFAULT NULL, PRIMARY KEY (id), KEY uid (uid) ) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=6; \[3\] #### 引用[.reference_title] - *1* [MySQL中or语句的使用方法](https://blog.csdn.net/weixin_32165903/article/details/113305027)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [MySQL语句之or/and](https://blog.csdn.net/haibo0668/article/details/79484846)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [mysql or语句的优化](https://blog.csdn.net/sunyuhua_keyboard/article/details/78352932)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值