01-动态sql
1.实现动态条件SQL
第一种方法在sql语句中加入where 1=1其他条件都加and就行,这样就可以根据if条件来判断要传递的参数可以有几个
data:image/s3,"s3://crabby-images/33906/33906ec74394b9f79acd2dd312b6fab07cf2cec7" alt=""
data:image/s3,"s3://crabby-images/7af18/7af18edc7e7dcc9446d483d5176c6db4bb23e950" alt=""
data:image/s3,"s3://crabby-images/601a6/601a6e0392865d516162218db247daa9875434f0" alt=""
data:image/s3,"s3://crabby-images/5c26a/5c26ac9a61f7f2acaef10ddc9dbb1ef45626729a" alt=""
第二种方法用where标签给if语句包起来
where标签的作用如下图
data:image/s3,"s3://crabby-images/36371/36371040b37abb7bc7c691dc1b03f7d970ed513f" alt=""
data:image/s3,"s3://crabby-images/9375e/9375e6cc4afe827f485ed40156172814fdb68400" alt=""
data:image/s3,"s3://crabby-images/3dab0/3dab017e9445a13f6647b76d43c2acd0b96936d0" alt=""
第三种方法用trim标签解释如下图
data:image/s3,"s3://crabby-images/c0864/c08644372f7d2c58808ed08708934e706ed87413" alt=""
用choose也可以实现条件查询如下图,when解释测试类里的deptName的值也就是接口里参数的值,如果对应到下面的经理或者员工就输出对应的sql语句,如果都没对应上就输出otherwise标签的内容
注意博主亲自测试过参数只有一个的情况下test后面的deptName和otherwise标签里#{id}里面的名字写成什么都可以
data:image/s3,"s3://crabby-images/f775b/f775bb408bfe08444f03a45189785efa9551a660" alt=""
data:image/s3,"s3://crabby-images/ef736/ef736014c5e5dbba55ea70f779c26ad46d05108a" alt=""
data:image/s3,"s3://crabby-images/788d9/788d94d2d403a88d78c8ee0c507e76cec9d6d54f" alt=""
data:image/s3,"s3://crabby-images/66646/6664694f9cb77b73c8297e52b8f1c264b496461a" alt=""
foreach循环的使用由于我们要查询多条数据可以用到foreach,foreach里的collection表示在测试类中传入的字符串数组名,看第三张图里的newString[],然后这个数组在xml文件里吗是我们给其的名字所以我们需要再接口中给这个变量名声明进去就是给它起个usernames的别名,item表示每次返回的一个对象,separator表示分割符,open表示循环开始的字符串,close表示循环结束的字符串,index表示传进来参数的下标
data:image/s3,"s3://crabby-images/eb1b8/eb1b86e8276c1af7d61b70b920487e3075ea8c7c" alt=""
data:image/s3,"s3://crabby-images/6f098/6f0983195eacd83e13485ad04c30f9fa5550323f" alt=""
data:image/s3,"s3://crabby-images/d6477/d64770973f169d7803ddd22b4dcfbe525788678f" alt=""
set的用法 set用在update里面用于sql语句自动添加set关键字和去除最后一个更新字段的逗号
data:image/s3,"s3://crabby-images/d40d5/d40d576e6b542cabd3a663a89a4ee59230791881" alt=""
mybatis要实现模糊查询的方法
第一种模糊查询需要用到%符号,我们用空格拼接的方法来进行模糊查询如下图两个%之间有空格
data:image/s3,"s3://crabby-images/070da/070daf1e8317761c779a55df7918f4c033af7ded" alt=""
第二种方法可以通过在测试类中拼接好来完成
data:image/s3,"s3://crabby-images/c5ccb/c5ccbfc30b457fbb51aee47f6ceeffe9136b3484" alt=""
data:image/s3,"s3://crabby-images/56f5e/56f5ed2070b858f7834a2cabcf34befb213be174" alt=""
第三种方法用bind设置个变量,里面传入值然后赋给#{},也能实现模糊查询
data:image/s3,"s3://crabby-images/14399/143994ee8f0907c27a772617ceb4dbb175cdda2c" alt=""
sql片段,减少重复代码,用法声明sql标签把重复用的sql语句方法标签里,然后想用的时候就用include refid=sql标签里的id名就行
data:image/s3,"s3://crabby-images/a0e4e/a0e4eb98f2d3e486bbb297dc05532e7b5f0a80c2" alt=""
sql标签还可以在查询的过程中设置查询的字段用include标签里面的property name属性可以随便赋值,value为你要查的数据库字段的名字,注意的是数据库字段里的名字,想要查多个参数可以用逗号然后写你要查的数据库字段,看下下图
data:image/s3,"s3://crabby-images/37901/37901429cea7ab244089ab8bbc8f1c0938163e15" alt=""
data:image/s3,"s3://crabby-images/b5d1c/b5d1cfe84312e973011910a43bcb1cc6fcf53044" alt=""
data:image/s3,"s3://crabby-images/9a4a9/9a4a95773b004692e39f2639fbd7b653647c3799" alt=""
mybatis批量插入的方法data:image/s3,"s3://crabby-images/9ddbb/9ddbbe5fa3111451316f57d7eb2f358a976b9910" alt=""
data:image/s3,"s3://crabby-images/48926/4892614b09443b0fbb9bd4959620a646aa181b74" alt=""
创建1000条数据方法
第一种list集合中,然后用for循环批量调用接口的方法实现批量插入
data:image/s3,"s3://crabby-images/c999b/c999b990b50dc4f990543226338ae68bd2174031" alt=""
第二种用foreach标签来实现逐条插入
首先在测试类中遍历一个list集合里面存入了1000个emp的数据
data:image/s3,"s3://crabby-images/13cf7/13cf7a24739dcd62a2e12a40a41887f7c868df52" alt=""
然后再.xml文件中用foreach 里的collection来接受传过来的1000个emp数据(注意用collection需要再接口上起个别名和collection属性名字一样的别名),如下下图所示
data:image/s3,"s3://crabby-images/9bfda/9bfdade7371dd26a7488a89d76cc0e8d6b3ad71b" alt=""
data:image/s3,"s3://crabby-images/126f0/126f0575e175228cab31b489ce10830fd4b2000b" alt=""
最后调用inserBatch接口方法实现批量插入
data:image/s3,"s3://crabby-images/58fcf/58fcf5e77aa4f9a168985594e53863add90b63ef" alt=""