java中的接口是类吗
386
2022-10-12
mybatis中xml之trim属性说明
mybatis的xml中trim标签有四个属性
1.prefix 前缀增加的内容
2.suffix 后缀增加的内容http://
3.prefixOverrides 前缀需要覆盖的内容,一般是第一个判断条件前面的多余的结构,如:第一个判断条件前面多了 ‘and'
4.suffixOverrides 后缀需要覆盖的内容,一般是最后一个数据的后面符号,如:set值的时候,最后一个值的后面多一个逗号‘,'
举几个例子:
1.根据用户姓名和年龄查询用户,有什么值就根据什么条件(目的是说明几个属性用法,可能例子不适用于实际场景中)
select * from User where name='zhangsan' and age='20';
select * from User
name = #{name}
and age = #{age}
上面例子是很常规的一个写法,第一个条件前面没有任何符号,第二个条件要加上and,否则sql语句会报错。很理想的状态是第一个和第二个都有值,但是既然判断,说明也可能会没有值,当第一个name没有值的时候,这个时候sql语句就会是
select * from User where and age='',很明显这个sql语句语法存在问题。在这里标签属性prefixOverrides就起作用了,它会让前缀where覆盖掉第一个and。覆盖之后的是:select * from User where age='';
前缀加上where就不说,因为属性 prefix='where',这个where 也可以写在
现在有更方便的标签了,就是
select * from User
name = #{name}
and age = #{age}
如果第一个name值是null,则age前面的and会被忽略掉。
再说说另两个属性,suffix和suffixOverrides。
如:更新用户的信息,哪些字段有值就更新哪些字段,sql语句如下:
update User
name=#{name},
age=#{age},
本例中最后一个条件中的逗号“,”会被后缀覆盖掉,本例中的后缀是where id =‘1';
OK,纯属为了说明四个属性怎么使用的,具体里面的值会根据具体需求而定。希望举一反三~
trim标签的使用场景
使用trim标签去除多余的逗号
如果红框里面的条件没有匹配上,sql语句会变成如下:
INSERT INTO role(role_name,) VALUES(roleName,)
插入将会失败。
做如下修改:
其中最重要的属性是
suffixOverrides=","
表示去除sql语句结尾多余的逗号.
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~