点滴记载,点滴进步,愿自己更上一层楼。
由于需要看到效果,所以这节最好可以将sql语句打印出来。参考 mybatis学习之路----打印sql语句
mybatis的if判断语句其实跟el表达式的if条件判断有些类似。
例如:
1 如果参数为数字类型的时候没有特俗需求的情况只需要判断是否为null即可。
例如:
如果有特俗需求,例如判断是否大于某个数的时候才行。只需要加上对应的条件判断即可
例如:
mybatis对于这种大于小于等等还有另一种形式。
例如:
对应关系:
---------------------------------------
gt 对应 >
gte 对应 >=
lt 对应 <(会报错 相关联的 "test" 属性值不能包含 '<' 字符)
lte 对应 <=(会报错 相关联的 "test" 属性值不能包含 '<' 字符)
---------------------------------------
2 如果为字符串类型
2.1 如果不需要过滤空串的情况 仅仅判断null即可
例如:
2.2 如果需要过滤空串,添加空串判断即可 不支持 && 所以这里用 and or || 来做逻辑与或的判断
例如:
2.3 如果判断字符串是否已某个特俗字符开头,结尾等。直接调用String的对应方法即可
例如:
2.4 是否是某个特定字符串,某些业务有此需要。
例如:
注意:
但是参数类型为非字符串类型的时候就需要写成
仅仅写成
也许你会说非字符串的为什么要写成这样。这就要看特俗需要了。
例如:某一个sql片段是公用的,
该片段更新条件也用,但是当你需要将某一个字段更新成null的时候怎么办。
这个时候就可以通过传入一个特定的字符串来弄。当传入的字符串为特定字符串的时候就更新该字符串为null。
当然这样子貌似date型会挂。
通过 2.2 也可以看出mybatis对于字符串的相等不相等的判断也是有对应的特俗操作符的。
-------------------------------------------------------
eq 对应 ==
neq 对应 !=
------------------------------------------------------
当然还可以看出来if的条件判断test是支持对象自身方法调用的,即使是自己写的方法,可以自己尝试。当然下面会有例子。
例如:里面可以用‘xxxx’.equals(xxxx) 字符串的比较两个字符串方法
xxxx.indexOf('ss') 判断字符串里面是否包含某个字符等等
3 判断list是否为空
上面说过,if条件判断可以直接调用对象自身的方法进行逻辑判断,所以list判空。可以调用.size()>0或者.isEmpty()
例如:
4 map参数同同理 取值的话 map.key(map中的key名字)即可
----------------------------------------------------------------------------------------------分割线01-----------------------------------------------------------------------------------------------------------
这里是上面的各种理论的实践。这里可以不看,自己去实践最好。
1 数字类型。
仅作null判断。
当id不为null的时候 打印的log
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and id=?
DEBUG [main] - ==> Parameters: 28(Integer)
DEBUG [main] - <== Total: 1
当id为null的时候 打印的log
DEBUG [main] - ==> Preparing: select * from t_user where 1=1
DEBUG [main] - ==> Parameters:
DEBUG [main] - <== Total: 1
两项对比,可以看出id=?这个条件随着传入参数id的变化而变化。
当有特俗需求的时候,当前数据库中的表id为28 仅仅有这么一条数据,做一下轻微的改动
当传入id=28的时候
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and id=?
DEBUG [main] - ==> Parameters: 28(Integer)
DEBUG [main] - <== Total: 1
当传入id小于28的时候
DEBUG [main] - ==> Preparing: select * from t_user where 1=1
DEBUG [main] - ==> Parameters:
DEBUG [main] - <== Total: 1
接下来测试下面这几种对应关系。
---------------------------------------
gt 对应 >
gte 对应 >=
lt 对应 <(会报错 相关联的 "test" 属性值不能包含 '<' 字符)
lte 对应 <=(会报错 相关联的 "test" 属性值不能包含 '<' 字符)
---------------------------------------
gt
参数 id=25
DEBUG [main] - ==> Preparing: select * from t_user where 1=1
DEBUG [main] - ==> Parameters:
参数 id=28
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and id=?
DEBUG [main] - ==> Parameters: 28(Integer)
>=
参数 id=28
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and id=?
DEBUG [main] - ==> Parameters: 28(Integer)
参数 id=27
DEBUG [main] - ==> Preparing: select * from t_user where 1=1
DEBUG [main] - ==> Parameters:
gte
参数 id=28
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and id=?
DEBUG [main] - ==> Parameters: 28(Integer)
参数 id=27
DEBUG [main] - ==> Preparing: select * from t_user where 1=1
DEBUG [main] - ==> Parameters:
使用 < <= 直接报错 "test" 属性值不能包含 '<' 字符 看来只能用 lt lte了
lt
参数 id=28
参数 id=27
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and id=?
DEBUG [main] - ==> Parameters: 27(Integer)
lte
参数 id=28
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and id=?
DEBUG [main] - ==> Parameters: 28(Integer)
参数 id=29
DEBUG [main] - ==> Preparing: select * from t_user where 1=1
DEBUG [main] - ==> Parameters:
----------------------------------------------------------------------------------------------分割线02-----------------------------------------------------------------------------------------------------------
2.1 跟1的第一条一样不做重复测试
2.2 过滤空串
!=
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and username=?
DEBUG [main] - ==> Parameters: xiao(String)
username=“”
DEBUG [main] - ==> Preparing: select * from t_user where 1=1
DEBUG [main] - ==> Parameters:
neq
username=“xiao”
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and username=?
DEBUG [main] - ==> Parameters: xiao(String)
username=“”
DEBUG [main] - ==> Preparing: select * from t_user where 1=1
DEBUG [main] - ==> Parameters:
and上面已经弄过了,这里弄or || 两种条件
or
username=“xiao”
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and username=?
DEBUG [main] - ==> Parameters: xiaohong(String)
username=“xiaofang”
DEBUG [main] - ==> Preparing: select * from t_user where 1=1
DEBUG [main] - ==> Parameters:
||
username=“xiao”
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and username=?
DEBUG [main] - ==> Parameters: xiao(String)
username=“xiaohong”
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and username=?
DEBUG [main] - ==> Parameters: xiaohong(String)
username=“xiaofang”
DEBUG [main] - ==> Preparing: select * from t_user where 1=1
DEBUG [main] - ==> Parameters:
username=“xiao”
DEBUG [main] - ==> Preparing: select * from t_user where 1=1 and username=?
DEBUG [main] - ==> Parameters: xiao(String)
username=“xiaofang”
2.4 判断是否是某个字符
username=“xiaohong”
==> Preparing: select * from t_user where 1=1 and username=?
==> Parameters: xiaohong(String)
username=“xiaofang”
==> Preparing: select * from t_user where 1=1
==> Parameters:
3 4 的本质就是再说mybatis的if条件判断语句可以直接执行对象的方法。下面自己写一个方法,在if里面试试。
自己定义一个类,里面一个方法用于条件判断用。
public class DynamicSql1Model {
public boolean getMySelfMethod(){
return true;
}
}
该类作为一个属性放入到model中 仅仅贴出部分代码
public class DynamicSqlModel {
private int id;
private String username;
private String password;
private Date createDate;
private List list;
private Map mapParam;
private DynamicSql1Model dynamicSql1Model;
xml中引用该model的方法
开始测试
DynamicSqlModel user = new DynamicSqlModel();
user.setUsername("xiaofang");
user.setPassword("123456");
user.setCreateDate(new Date());
DynamicSql1Model dynamicSqlModel = new DynamicSql1Model();
user.setDynamicSql1Model(dynamicSqlModel);
dao.selectUseIf(user);
现在返回结果
现在方法的返回值为true
==> Preparing: select * from t_user where 1=1 and username=?
==> Parameters: xiaofang(String)
方法返回值修改为false
==> Preparing: select * from t_user where 1=1
==> Parameters:
可以看出完全可以使用自定义的方法进行if条件控制。通过该特性可以干一些特俗业务的事情。自己体会。
本篇说的主要是if条件判断动态控制sql。可以看出有弊端。因为if条件不满足的时候sql会变成
select * from t_user where 所以我在条件后面加了个 1=1 但是这是不符合逻辑的。下节介绍where以及其他标签用于动态sql。