Mybatis学习笔记8 查询返回专题_biubiubiu0706的博客-CSDN博客
动态SQL的业务场景:
例如
批量删除
get请求 uri?id=18&id=19&id=20 或者post id=18&id=19&id=20
String[] ids=request.getParameterValues("id")
那么这句SQL是需要动态的
还有像如下的多条件查询
可能不提供条件: 0条件 select & from t_product;
当选择了一个或多个条件: select * from t_product where 条件1=#{xxx} and 条件2=#{xxx2}
新建模块
1. if标签
2.where标签 作用让where子句更加动态智能
当所有条件都为空时,where标签保证不会生成where子句
自动去除某些条件前面多余的and和or
3.trim标签
prefix:在trim标签中的语句前添加内容
suffix:在trim标签中的语句后 添加 内容
prefixOverrides:前缀覆盖掉(去掉)
suffixOverrides:后缀 覆盖掉(去掉)
data:image/s3,"s3://crabby-images/a645e/a645e37a816f05734e19b63479e53a7f2741621c" alt=""
trim会自动判断里面if来考虑是否添加where 并且自动判断是否去掉 and或者or
data:image/s3,"s3://crabby-images/d0192/d0192b506e96e97a182acba8a825233c2cec9a4f" alt=""
4.set标签
主要使⽤在update语句当中,⽤来⽣成set关键字,同时去掉最后多余的“,”
data:image/s3,"s3://crabby-images/7af46/7af46bae0d8c2ba9b2c6f2342ffdb59302387afa" alt=""
data:image/s3,"s3://crabby-images/be632/be632d921dc402ce459857727adeba02fbf8a46d" alt=""
data:image/s3,"s3://crabby-images/e8289/e82895deb1fa2448984719efb813dd0fb04d4dba" alt=""
5.choose when otherwise
< choose >
< when ></ when >
< when ></ when >
< when ></ when >
< otherwise ></ otherwise >
</ choose >
一般<choose>会和<when><otherwise>联合使用
等价于
if (){
} else if (){
} else if (){
} else if (){
} else {
}
只有⼀个分⽀会被选择!!!! 只要一个分支执行,条件语句结束 只有⼀个分⽀会被选择,且必会选择!!!!只有⼀个分⽀会被选择,且必会选择!!!!只有⼀个分⽀会被选择,且必会选择!!!!只有⼀个分⽀会被选择,且必会选择!!!!只有⼀个分⽀会被选择,且必会选择!!!!只有⼀个分⽀会被选择,且必会选择!!!!
if (){
} else if (){
} else if (){
} else if (){
} else {
}
只有⼀个分⽀会被选择!!!! 只要一个分支执行,条件语句结束 只有⼀个分⽀会被选择,且必会选择!!!!只有⼀个分⽀会被选择,且必会选择!!!!只有⼀个分⽀会被选择,且必会选择!!!!只有⼀个分⽀会被选择,且必会选择!!!!只有⼀个分⽀会被选择,且必会选择!!!!只有⼀个分⽀会被选择,且必会选择!!!!
比如说下面的三个参数都是""或者 null
那么 最后执行
select * from t_car where car_type= "" 或者 select * from t_car where car_type= null
实际使用比如
比如需求是:先根据品牌查,没有提供品牌按价格查,没有提供价格按类型查
data:image/s3,"s3://crabby-images/51ba2/51ba2ec85e72bfb5aa1ac6957170b33424915401" alt=""
data:image/s3,"s3://crabby-images/6e524/6e524939a47a58cf7ec1ae6adef95bd5be4e879b" alt=""
这里注意下
data:image/s3,"s3://crabby-images/c437c/c437cb8bb0f48bb4f09eadee1b6e7d936e7e667e" alt=""
6.foreach标签
循环数组或集合,动态⽣成sql
批量删除:
id=1&id=2&id=3
String[] ids=request.getParameterValues("id");
String[] ids={"1","2","3"}
int[] intArray = new int[idValues.length];
for (int i = 0; i < idValues.length; i++) {
try {
intArray[i] = Integer.parseInt(idValues[i]);
} catch (NumberFormatException e) {
}
delete from t_car where id in ( 1 , 2 , 3 );
delete from t_car where id = 1 or id = 2 or id = 3 ;
第一种方式: delete from t_car where id in ( 1 , 2 , 3 );
data:image/s3,"s3://crabby-images/5c0ce/5c0ce558ac72886bddc3034307e71c6c027380d1" alt=""
data:image/s3,"s3://crabby-images/bbdf0/bbdf0346b74b14323ed971f3fa46031d5e3be91f" alt=""
第二种方式: delete from t_car where id = 1 or id = 2 or id = 3 ;
data:image/s3,"s3://crabby-images/6bfdb/6bfdb1bfe37c195470774fe8d1cd2f7f85a560a2" alt=""
data:image/s3,"s3://crabby-images/dc79b/dc79b907bbd563932afd997be3fe30446a1ca664" alt=""
批量插入
比如 一次插入多条数据
insert into user(id,name,age) values(1,'zs',18),(2,'ls',19),(3,'ww',21)
data:image/s3,"s3://crabby-images/5b7c8/5b7c88dfd27603ade9e00430947d78d429d2ce03" alt=""
data:image/s3,"s3://crabby-images/bc213/bc21319844be4044b5d0d13978351b718cb37119" alt=""
data:image/s3,"s3://crabby-images/3c4a4/3c4a4e1dc83f1d075bde4cd1f272e1ad0ed63e31" alt=""
7 sql标签与include标签
sql标签⽤来声明sql⽚段
include标签⽤来将声明的sql⽚段包含到某个sql语句当中
作⽤:代码复⽤。易维护。
例如
data:image/s3,"s3://crabby-images/95247/952470ad071bdf44b700cf31fef6f0551b570c1e" alt=""