区别:
- isNotNull:表示参数不为NULL,返回TRUE反之则为FALSE
- isNull:表示参数为NULL,返回TRUE反之则为FALSE
- isNotEmpty:表示参数不为NULL也不为空,返回TRUE反之则返回FALSE
- isEmpty:表示参数为NULL或着为空,返回TRUE反之则为FALSE
例:当xml代码中用isNotEmpty配置时
<select id="queryTable" resultClass="int" parameterClass="QryCondition">
select count(id) from table
<dynamic prepend="WHERE">
<isNotEmpty prepend="AND" property="abc">
( table.filed1 LIKE '%$abc$%')
</isNotEmpty>
<isNotEmpty prepend="AND" property="def">
( table.filed2 LIKE '%$def$%')
</isNotEmpty>
</dynamic>
</select>
当之传入参数 abc 而不传入 def 时,产生的SQL语句为:
select count(id) from table where(table.filed1 LIKE '%abc%');
当XML代码中用isNotNull配置时(注意他们的区别):
<select id="queryTable" resultClass="int" parameterClass="QryCondition">
select count(id) from table
<dynamic prepend="WHERE">
<isNotNull prepend="AND" property="abc">
(table.field1 LIKE '%$abc$%')
</isNotNull>
<isNotNull prepend="AND" property="def">
(table.field2 LIKE '%$def$%')
</isNotNull>
</dynamic>
</select>
同样 ,当传入参数 abc 而不传入 def 时,产生的SQL语句为:
select count(id) from table
where (table.field1 LIKE '%abc%') AND (table.field2 LIKE '%%')
注意:
必须使用ISNULL()来判断是否为NULL值。
说明:NULL与任何值的直接比较都为NULL。
1) NULL<>NULL的返回结果是NULL,而不是false。
2) NULL=NULL的返回结果是NULL,而不是true。
3) NULL<>1的返回结果是NULL,而不是true。
点击查看更多内容
1人点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦