前段时间看到了一个MYSQL数据库的sql的用法,是一个早就有的sql语法,但是从来没使用过,也没见过,当时就看了一下。
今天业务上有个需求刚好符合使用这种语法的情况,我就想去找找,结果忘记这个语法叫什么名字了,资料来源也找不到了,抓瞎…
只能记得大概怎么写,然后尝试了一下,可以。所以记录一下,怕后面又忘了。
一般使用in 大多是 select * from table where field in( v1,v2,v3,v4,...)
这样的用法,
mybatis写法也是
field in (
<foreach collection="list" item="item" separator=","> #{item} </foreach>
)
我这次的需求是需要同时满足2个字段再某个集合范围内,就是类似于这样:
(
(field1 = value1_1 and field2 = value2_1)
or (field1 = value1_2 and field2 = value2_2)
or (field1 = value1_3 and field2 = value2_3)
or ....
)
用这种写法(这种写法叫什么名字至今还不知道)就是这样:
(field1 , field2) in (
(value1_1 , value2_1) ,
(value1_2 , value2_2) ,
(value1_3 , value2_3) ,
(value1_4 , value2_4) , ...
)
mybatis写法就像这样:
list是一个对象
(field1, field2) in(
<foreach collection="list" item="item" separator=",">
(#{item.system} ,#{item.menu} )
</foreach>
)
2个字段这样写,多个字段等都类似,这样写在某些需要多字段条件同时配置时可以避免像最上面那样产生多个 or 连接,这些字段如果有索引还能走索引。
记录一下