dynamic可以去除第一个prepend="and"中的字符(这里为and),从而可以帮助你实现一些很实用的功能。具体情况如下:
1.使用dynamic
1.1 xml
select * from Person表
<dynamic prepend="where">
<isNotNull property="name" prepend="and">
name=#name#
</isNotNull>
<isNotNull property="sex" prepend="and">
sex=#sex#
</isNotNull>
</dynamic>1.2 结果
当name、sex都非null时打出如下的sql语句:
select Person表 where (and) name= ? , and sex= ?
显然name前的and被自动去除了,很方便吧。
2.不使用dynamic
2.1 xml
如果我把dynamic 去掉就会变的很恶心,如下:
select * from Person表
<isNotNull property="name" prepend="and">
name=#name#
</isNotNull>
<isNotNull property="sex" prepend="and">
sex=#sex#
</isNotNull> 2.2 结果
当name、sex都非null时打出如下的sql语句:
select Person表 where and name= ? , and sex= ?
显然name前多个and,sql语句错误。
3.总结
dynamic 会自动去除第一个 prepend="and中的内容(这里为and),从而方便一些操作。
本文介绍如何使用动态SQL技术去除冗余条件,优化SQL语句,提高查询效率。通过实例演示了如何在XML配置中利用动态SQL组件去除多余的'and'关键字,避免SQL错误,提升开发体验。
359

被折叠的 条评论
为什么被折叠?



