动态查询条件
<select id="SelectEemployee" parameterClass="string" resultMap = "employee-result">
select * from employee
//动态SQL语句
<dynamic prepend="WHERE">
<isParameterPresent>
emp_id = #value#
</isParameterPresent>
</dynamic>
</select>
</statements>
</sqlMap>
/*动态SQL的写法:
开始 <dynamic
条件成立时前面要加的字符串 prepend ="字符串">
<属性关键字 (见下表)
prepend="字符串"
判断条件的对象属性名 property="字符串"
如果是属性关键字是比较条件时,字符串存放要比较的值compareValue="字符串">
要显示的条件名
</属性关键字>
结束</dynamic>
*/
/*动态SQL的参数有
属性关键字
含义
<isEqual>
如果参数相等于值则查询条件有效。
<isNotEqual>
如果参数不等于值则查询条件有效。
<isGreaterThan>
如果参数大于值则查询条件有效。
<isGreaterEqual>
如果参数等于值则查询条件有效。
<isLessEqual>
如果参数小于值则查询条件有效。如下所示:
<isLessEqual prepend = ”AND” property = ”age” compareValue = ”18” >
ADOLESCENT = ‘TRUE’
</isLessEqual>
<isPropertyAvailable>
如果参数有使用则查询条件有效。
<isNotPropertyAvailable>
如果参数没有使用则查询条件有效。
<isNull>
如果参数为NULL则查询条件有效。
<isNotNull>
如果参数不为NULL则查询条件有效。
<isEmpty>
如果参数为空则查询条件有效。
<isNotEmpty>
如果参数不为空则查询条件有效。参数的数据类型为Collection、String 时参数不为NULL或“”。如下所示:
<isNotEmpty prepend=”AND” property=”firstName” >
FIRST_NAME=#firstName#
</isNotEmpty>
<isParameterPresent>
如果参数类不为NULL则查询条件有效。
<isNotParameterPresent>
Checks to see if the parameter object is not present (null). Example Usage:
<isNotParameterPresent prepend=”AND”>
EMPLOYEE_TYPE = ‘DEFAULT’
</isNotParameterPresent>
eg1:
<select id="getList" resultMap="FriendResult">
select f.userid1,f.userid2,f.state1,f.subdate,f.cardno,b.grade,f.nickname,f.gender,f.age,f.city,b.username,b.userid,b.city,b.state,b.gender,b.cardno,d.* from friend f ,basicuserinfo b,detailuserinfo d where b.userid = f.userid2 and f.userid2=d.userid and f.state1=#state1#
<dynamic prepend="and">
<isNotEqual prepend="and" property="userid1" comparevalue="0">
f.userid1=#userid1#
</isNotEqual>
<isNotEqual prepend="and" property="userid2" comparevalue="0">
f.userid2=#userid2#
</isNotEqual>
</dynamic>
</select>
eg2:
<select id="getNewsList" resultMap="newsResult" parameterClass="map">
select NEWS_ID,BLOCK_ID,NEWS_TITLE,NEWS_CONTENT,NEWS_SECONDTITLE,NEWS_SUMMARY,NEWS_AUTHOR,NEWS_SOURCE,NEWS_ANNEX,NEWS_TIME,NEWS_OPEN,NEWS_KEYWORDS,NEWS_APPROVE,ISTOP,BROWSENUM,NEWS_COMMENT,NEWS_REFUSE,NEWS_AUDITOR,lasteditor,prjid,prjname,wsflag,MEM_NAME,LASTEDITTIME,ISBLOCKPIC from yc_news where BLOCK_ID = #blockid#
<dynamic prepend="ORDER BY">
<isNotEmpty property="orderstr">
$orderstr$
</isNotEmpty>
</dynamic>
</select>
分享到:
相关推荐
NULL 博文链接:https://raymondwang1314.iteye.com/blog/1195820
很好的spring+ibatis事务的配置文档.
ibatis用xml配置文件配置的使用,基本包括了ibatis遇到的所有问题
ibatis配置ibatis配置ibatis配置ibatis配置ibatis配置 以及相关资料
学会ibatis 中sqlMap配置
SPRING与IBATIS整合采用保留IBATIS事务,可自己控制回滚!
Ibatis动态查询配置文件的讲解,来下载吧,好久才弄的哦!
ibatis 实例 配置 源码 依赖包 ibatis-2.3.4.726.jar commons-logging-api.jar commons-logging-1.1.jar commons-dbcp-1.2.2.jar commons-pool.jar
此文本主要是关于ibatis总配置和映射配置和一些需要主要的细节。
ibatis 配置文件详解
ibatis的配置文件和映射文件,以及ibatis的应用
操作数据库 iBATIS查询,java 和spring的配置方法
ibatis 使用简单配置
iBATIS是以SQL为中心的持久化层框架。能支持懒加载、关联查询、继承等特性
oracle ibatis 配置
Ibatis基本配置---[环境搭建
常用IBATIS配置,返回新建数据ID,分页查询,查询条件,模糊查询,date时间段,list集合,截止日期
SPRING与IBATIS整合采用保留IBATIS事务,可自己控制回滚!
spring ibatis 配置spring ibatis 配置spring ibatis 配置spring ibatis 配置
ibatis_SqlMapConfig配置详解,希望对初次接触ibatis的童鞋,有帮助