1.#{}取值相当于在内容前后加上'',但不全是,比如把内容为'1','2'的string值去掉前后的"'"成为1','2,然后xml中#{}取出放在sql的in语句(#{})中,结果还是和in('1','2')有区别。
2.${}取值是内容原样拼接到sql中,但是里面的参数不能是直接的简单参数,而应该是复杂参数的属性,否则报这个属性没有getter方法,如 dao或者mapper中query(String a),
xml中如果${a}获取值则会报前面说的错误,要把a封装到map中,或者自定义类型的对象中,属性为a,则${a}才不会报错
3.当xml中方法传入的是简单参数,如query(String a),如果与<if test>使用,则要么在对应的dao方法参数a之前加上@Param注解(如query(@Param("a") String a)),要么就在<if test>用_parameter代替a(如<if test="_parameter">,而不能写成<if test="a != null">)。否则也会报找不到属性的getter方法错误。
4.<if test>字符串比较时注意单引号和双引号的区别,如果a为空字符串,那么<if test='a == ""'>正确,但是<if test="a == ''">就是错误的,因为后者的意思是把一个字符串a和一个空字符(单引号被识别为字符)比较,在java中当然不相等。
可以写成<if test="a == ''.toString()">或者<if test="a == \"\"">
mybatis中的一些坑
最新推荐文章于 2024-04-03 17:46:20 发布