sql-or与and的配合使⽤
关于对sql语句中的or与and,进⾏深⼊解剖
⼀:优先级
and > or
⼆:使⽤场景
1.批量修改
update*** a set a.is_del =1
where a.is_del =0and a.edu_name = ? and a.project_name = ?
or a.is_del =0and a.edu_name = ? and a.project_name = ?
or a.is_del =0and a.edu_name = ? and a.project_name = ?
or a.is_del =0and a.edu_name = ? and a.project_name = ?
or a.is_del =0and a.edu_name = ? and a.project_name = ?
这语句的意思是,更新表的参数is_del = 1,当is_del = 0且edu_name 与project_name 都符合条件时 或 当is_del = 0且edu_name 与project_name 都符合条件时 …所以,当and与or同时出现时,or会⾃动分成⼀份份,就像循环⼀样,只要其中⼀个or的成⽴了,都会修改到,这样就实现了批量修改了。当然,每个or的条件可以不⼀样,但是每个or之前都是互不影响的。
2.多参数列查询
select a.*批量更新sql语句
from film_info a
left join film_type_info b on a.film_id = b.film_info_id
left join film_type c on c.film_type_id = b.film_type_id
<if test="searchInfo!=null and searchInfo!=''">
where
(
a.film_name like CONCAT('%',#{searchInfo},'%')
or a.film_message like CONCAT('%',#{searchInfo},'%')
or c.film_type like CONCAT('%',#{searchInfo},'%')
)
and a.is_del =0
</if>
这语句意思为,查询a.film_name 或 a.film_message 或 c.film_type符合条件时,并且a.is_del =0 的数据,这个括号就把或的查询都放到了⼀起,这样我们就能实现我们想要的效果了,如果不加括号,那就会跟上⾯⼀样,⾃动分割,但是显然不是我们想要的效果。
结语:关于or的使⽤,只要把握好优先级,能使编写代码事半功倍,还能优化性能,批量delete就不写出来了,因为不建议使⽤delete硬删除,⼀般项⽬都是会对数据留底,那么删除也就使⽤软删除最好,毕竟delete了就真的没了。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。