关于ibatis动态sql的prepend的属性,我们需要理解一下几点
select * from student
<dynamic prepend="where">
<isNotNull property="id" prepend="and">
id = #id#
</isNotNull>
<isNotNull property="name" prepend="and">
name like '%$name$%'
</isNotNull>
</dynamic>
要点一 prepend是添加在动态语句的前面
and是添加在id = #id#,同样and是添加在name like '%$name$%'前面
要点二 dynamic中首个prepend被忽略
按照要点一说法,语句select * from studnet and id = #id#就会出现问题了。其实若<isNotNull>写在<dynamic>里,且包含prepend,第一个isNotNull的prepend会被忽略。有的人会说,id不加prepend,变成<isNotNull property="id">?那就错了,因为name前面的and会被过滤掉了,会出错。
要点三 明白了要点二,可以理解拼接语句中遇到的一些错误问题
分享到:
相关推荐
ibatis的dynamicSQL中,关于prepend的使用
ibatis sql语句对条件中特殊字符% # 处理
IBATIS动态查询语句.doc
iBatis最全的动态SQL语句,你需要的都有,资源在于大家共享
ibatis sql 语句的编写 ,包括增删改查,很简单 很实用 ,对初学者是很好的选择
在ibatis日志信息中打印SQL语句的方法(个人总结)
ibatis常用sql语句,简单易懂,方便查询,初学者宝典
Ibatis查询语句里,可以使用多表查询,返回多个表的值.doc
ibatis常用的sql语句,很全的一篇文档。。。
ibatis16个常用sql语句
ibatis中使用安全的拼接语句,动态查询,大于、小于、等于.doc
ibatis查询语句配对.doc
NULL 博文链接:https://raymondwang1314.iteye.com/blog/1195820
NULL 博文链接:https://yhq1212.iteye.com/blog/1772214
自己整理的非常好用 好东西向大家分享 └ ^o^ ┘
Ibatis复杂查询语句.doc
ibatis动态多条件组合查询 实例 说明
iBATIS动态标签 §标签 §二元标签 §一元标签 §标签 § 共同的属性 prepend,open,close 标签 §标签 §属性 prepend,open,close 二元条件标签
ibatis_动态查询条件详解及需要注意的地方
ibatis动态注入