ibatis常用sql

(1) 输入参数为单个值

Xml代码

  1. <delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore"
  2. parameterClass="long">
  3. delete from
  4. MemberAccessLog
  5. where
  6. accessTimestamp = #value#
  7. </delete>
<delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore"
parameterClass="long">
delete from
MemberAccessLog
where
accessTimestamp = #value#
</delete>

 
(2) 输入参数为一个对象

Xml代码

  1. <insert id="com.fashionfree.stat.accesslog.MemberAccessLog.insert"
  2. parameterClass="com.fashionfree.stat.accesslog.model.MemberAccessLog>
  3. insert into MemberAccessLog
  4. (
  5. accessLogId, memberId, clientIP,
  6. httpMethod, actionId, requestURL,
  7. accessTimestamp, extend1, extend2,
  8. extend3
  9. )
  10. values
  11. (
  12. #accessLogId#, #memberId#,
  13. #clientIP#, #httpMethod#,
  14. #actionId#, #requestURL#,
  15. #accessTimestamp#, #extend1#,
  16. #extend2#, #extend3#
  17. )
  18. </insert>
<insert id="com.fashionfree.stat.accesslog.MemberAccessLog.insert"
parameterClass="com.fashionfree.stat.accesslog.model.MemberAccessLog>
insert into MemberAccessLog
(
accessLogId, memberId, clientIP,
httpMethod, actionId, requestURL,
accessTimestamp, extend1, extend2,
extend3
)
values
(
#accessLogId#, #memberId#,
#clientIP#, #httpMethod#,
#actionId#, #requestURL#,
#accessTimestamp#, #extend1#,
#extend2#, #extend3#
)
</insert>

(3) 输入参数为一个java.util.HashMap 

Xml代码

  1. <select id="com.fashionfree.stat.accesslog.selectActionIdAndActionNumber"
  2. parameterClass="hashMap"
  3. resultMap="getActionIdAndActionNumber">
  4. select
  5. actionId, count(*) as count
  6. from
  7. MemberAccessLog
  8. where
  9. memberId = #memberId#
  10. and accessTimestamp &gt; #start#
  11. and accessTimestamp &lt;= #end#
  12. group by actionId
  13. </select>
<select id="com.fashionfree.stat.accesslog.selectActionIdAndActionNumber"
parameterClass="hashMap"
resultMap="getActionIdAndActionNumber">
select
actionId, count(*) as count
from
MemberAccessLog
where
memberId = #memberId#
and accessTimestamp &gt; #start#
and accessTimestamp &lt;= #end#
group by actionId
</select>

 

  (4) 输入参数中含有数组

   

Xml代码

  1. <insert id="updateStatusBatch" parameterClass="hashMap">
  2. update
  3. Question
  4. set
  5. status = #status#
  6. <dynamic prepend="where questionId in">
  7. <isNotNull property="actionIds">
  8. <iterate property="actionIds" open="(" close=")" conjunction=",">
  9. #actionIds[]#
  10. </iterate>
  11. </isNotNull>
  12. </dynamic>
  13. </insert>
<insert id="updateStatusBatch" parameterClass="hashMap">
update
Question
set
status = #status#
<dynamic prepend="where questionId in">
<isNotNull property="actionIds">
<iterate property="actionIds" open="(" close=")" conjunction=",">
#actionIds[]#
</iterate>
</isNotNull>
</dynamic>
</insert> 

说明:actionIds为传入的数组的名字; 
   使用dynamic标签避免数组为空时导致sql语句语法出错;
   使用isNotNull标签避免数组为null时ibatis解析出错

   (5)传递参数只含有一个数组 

Xml代码

  1. <select id="com.fashionfree.stat.accesslog.model.StatMemberAction.selectActionIdsOfModule"
  2. resultClass="hashMap">
  3. select
  4. moduleId, actionId
  5. from
  6. StatMemberAction
  7. <dynamic prepend="where moduleId in">
  8. <iterate open="(" close=")" conjunction=",">
  9. #[]#
  10. </iterate>
  11. </dynamic>
  12. order by
  13. moduleId
  14. </select>
<select id="com.fashionfree.stat.accesslog.model.StatMemberAction.selectActionIdsOfModule"
resultClass="hashMap">
select
moduleId, actionId
from
StatMemberAction
<dynamic prepend="where moduleId in">
<iterate open="(" close=")" conjunction=",">
#[]#
</iterate>
</dynamic>
order by
moduleId
</select> 

说明:注意select的标签中没有parameterClass一项
       另:这里也可以把数组放进一个hashMap中,但增加额外开销,不建议使用

(6)让ibatis把参数直接解析成字符串 

Xml代码

  1. <select id="com.fashionfree.stat.accesslog.selectSumDistinctCountOfAccessMemberNum"
  2. parameterClass="hashMap" resultClass="int">
  3. select
  4. count(distinct memberId)
  5. from
  6. MemberAccessLog
  7. where
  8. accessTimestamp &gt;= #start#
  9. and accessTimestamp &lt; #end#
  10. and actionId in $actionIdString$
  11. </select>
<select id="com.fashionfree.stat.accesslog.selectSumDistinctCountOfAccessMemberNum"
parameterClass="hashMap" resultClass="int">
select
count(distinct memberId)
from
MemberAccessLog
where
accessTimestamp &gt;= #start#
and accessTimestamp &lt; #end#
and actionId in $actionIdString$
</select>

说明:使用这种方法存在sql注入的风险,不推荐使用

 (7)分页查询 (pagedQuery)

   

Java代码

  1. <select id="com.fashionfree.stat.accesslog.selectMemberAccessLogBy"
  2. parameterClass="hashMap" resultMap="MemberAccessLogMap">
  3. <include refid="selectAllSql"/>
  4. <include refid="whereSql"/>
  5. <include refid="pageSql"/>
  6. </select>
  7. <select id="com.fashionfree.stat.accesslog.selectMemberAccessLogBy.Count"
  8. parameterClass="hashMap" resultClass="int">
  9. <include refid="countSql"/>
  10. <include refid="whereSql"/>
  11. </select>
  12. <sql id="selectAllSql">
  13. select
  14. accessLogId, memberId, clientIP,
  15. httpMethod, actionId, requestURL,
  16. accessTimestamp, extend1, extend2,
  17. extend3
  18. from
  19. MemberAccessLog
  20. </sql>
  21. <sql id="whereSql">
  22. accessTimestamp &lt;= #accessTimestamp#
  23. </sql>
  24. <sql id="countSql">
  25. select
  26. count(*)
  27. from
  28. MemberAccessLog
  29. </sql>
  30. <sql id="pageSql">
  31. <dynamic>
  32. <isNotNull property="startIndex">
  33. <isNotNull property="pageSize">
  34. limit #startIndex# , #pageSize#
  35. </isNotNull>
  36. </isNotNull>
  37. </dynamic>
  38. </sql>
<select id="com.fashionfree.stat.accesslog.selectMemberAccessLogBy"
parameterClass="hashMap" resultMap="MemberAccessLogMap">
<include refid="selectAllSql"/>
<include refid="whereSql"/>
<include refid="pageSql"/>
</select>
<select id="com.fashionfree.stat.accesslog.selectMemberAccessLogBy.Count"
parameterClass="hashMap" resultClass="int">
<include refid="countSql"/>
<include refid="whereSql"/>
</select>
<sql id="selectAllSql">
select
accessLogId, memberId, clientIP,
httpMethod, actionId, requestURL,
accessTimestamp, extend1, extend2,
extend3
from
MemberAccessLog
</sql>
<sql id="whereSql">
accessTimestamp &lt;= #accessTimestamp#
</sql>
<sql id="countSql">
select
count(*)
from
MemberAccessLog
</sql>
<sql id="pageSql">
<dynamic>
<isNotNull property="startIndex">
<isNotNull property="pageSize">
limit #startIndex# , #pageSize#
</isNotNull>
</isNotNull>
</dynamic>
</sql>

   说明:本例中,代码应为:
   HashMap hashMap = new HashMap();
   hashMap.put(“accessTimestamp”, someValue);
   pagedQuery(“com.fashionfree.stat.accesslog.selectMemberAccessLogBy”, hashMap); 
   pagedQuery方法首先去查找名为com.fashionfree.stat.accesslog.selectMemberAccessLogBy.Count 的mapped statement来进行sql查询,从而得到com.fashionfree.stat.accesslog.selectMemberAccessLogBy查询的记录个数,
再进行所需的paged sql查询(com.fashionfree.stat.accesslog.selectMemberAccessLogBy),具体过程参见utils类中的相关代码

(8)sql语句中含有大于号>、小于号<

    1. 将大于号、小于号写为: &gt; &lt; 如:

Xml代码

  1. <delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore" parameterClass="long">
  2. delete from
  3. MemberAccessLog
  4. where
  5. accessTimestamp &lt;= #value#
  6. </delete>
<delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore" parameterClass="long">
delete from
MemberAccessLog
where
accessTimestamp &lt;= #value#
</delete> 

2. 将特殊字符放在xml的CDATA区内:

Xml代码

  1. <delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore" parameterClass="long">
  2. <![CDATA[
  3. delete from
  4. MemberAccessLog
  5. where
  6. accessTimestamp <= #value#
  7. ]]>
  8. </delete>
<delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore" parameterClass="long">
<![CDATA[
delete from
MemberAccessLog
where
accessTimestamp <= #value#
]]>
</delete> 

推荐使用第一种方式,写为&lt; 和 &gt; (XML不对CDATA里的内容进行解析,因此如果CDATA中含有dynamic标签,将不起作用)

(9)include和sql标签
   将常用的sql语句整理在一起,便于共用:

Xml代码

  1. <sql id="selectBasicSql">
  2. select
  3. samplingTimestamp,onlineNum,year,
  4. month,week,day,hour
  5. from
  6. OnlineMemberNum
  7. </sql>
  8. <sql id="whereSqlBefore">
  9. where samplingTimestamp &lt;= #samplingTimestamp#
  10. </sql>
  11. <select id="com.fashionfree.accesslog.selectOnlineMemberNumsBeforeSamplingTimestamp" parameterClass="hashmap" resultClass="OnlineMemberNum">
  12. <include refid="selectBasicSql" />
  13. <include refid="whereSqlBefore" />
  14. </select>
<sql id="selectBasicSql">
select
samplingTimestamp,onlineNum,year,
month,week,day,hour
from
OnlineMemberNum
</sql>
<sql id="whereSqlBefore">
where samplingTimestamp &lt;= #samplingTimestamp#
</sql>
<select id="com.fashionfree.accesslog.selectOnlineMemberNumsBeforeSamplingTimestamp" parameterClass="hashmap" resultClass="OnlineMemberNum">
<include refid="selectBasicSql" />
<include refid="whereSqlBefore" />
</select> 

注意:sql标签只能用于被引用,不能当作mapped statement。如上例中有名为selectBasicSql的sql元素,试图使用其作为sql语句执行是错误的:
    sqlMapClient.queryForList(“selectBasicSql”); ×

(10)随机选取记录

Xml代码

  1. <sql id=”randomSql”>
  2. ORDER BY rand() LIMIT #number#
  3. </sql>
<sql id=”randomSql”>
ORDER BY rand() LIMIT #number#
</sql> 

    从数据库中随机选取number条记录(只适用于MySQL)

(11)将SQL GROUP BY分组中的字段拼接

Xml代码

  1. <sql id=”selectGroupBy>
  2. SELECT
  3. a.answererCategoryId, a.answererId, a.answererName,
  4. a.questionCategoryId, a.score, a.answeredNum,
  5. a.correctNum, a.answerSeconds, a.createdTimestamp,
  6. a.lastQuestionApprovedTimestamp, a.lastModified, GROUP_CONCAT(q.categoryName) as categoryName
  7. FROM
  8. AnswererCategory a, QuestionCategory q
  9. WHERE a.questionCategoryId = q.questionCategoryId
  10. GROUP BY a.answererId
  11. ORDER BY a.answererCategoryId
  12. </sql>
<sql id=”selectGroupBy>
SELECT
a.answererCategoryId, a.answererId, a.answererName,
a.questionCategoryId, a.score, a.answeredNum,
a.correctNum, a.answerSeconds, a.createdTimestamp,
a.lastQuestionApprovedTimestamp, a.lastModified, GROUP_CONCAT(q.categoryName) as categoryName
FROM
AnswererCategory a, QuestionCategory q
WHERE a.questionCategoryId = q.questionCategoryId
GROUP BY a.answererId
ORDER BY a.answererCategoryId
</sql>

注:SQL中使用了MySQL的GROUP_CONCAT函数

(12) 按照IN里面的顺序进行排序

    ①MySQL:

Xml代码

  1. <sql id=”groupByInArea”>
  2. select
  3. moduleId, moduleName,
  4. status, lastModifierId, lastModifiedName,
  5. lastModified
  6. from
  7. StatModule
  8. where
  9. moduleId in (3, 5, 1)
  10. order by
  11. instr(‘,3,5,1,‘ , ‘,‘+ltrim(moduleId)+‘,‘)
  12. </sql>
<sql id=”groupByInArea”>
select
moduleId, moduleName,
status, lastModifierId, lastModifiedName,
lastModified
from
StatModule
where
moduleId in (3, 5, 1)
order by
instr(‘,3,5,1,‘ , ‘,‘+ltrim(moduleId)+‘,‘)
</sql> 

②SQLSERVER:

Xml代码

  1. <sql id=”groupByInArea”>
  2. select
  3. moduleId, moduleName,
  4. status, lastModifierId, lastModifiedName,
  5. lastModified
  6. from
  7. StatModule
  8. where
  9. moduleId in (3, 5, 1)
  10. order by
  11. charindex(‘,‘+ltrim(moduleId)+‘,‘ , ‘,3,5,1,‘)
  12. </sql>
<sql id=”groupByInArea”>
select
moduleId, moduleName,
status, lastModifierId, lastModifiedName,
lastModified
from
StatModule
where
moduleId in (3, 5, 1)
order by
charindex(‘,‘+ltrim(moduleId)+‘,‘ , ‘,3,5,1,‘)
</sql>

说明:查询结果将按照moduleId在in列表中的顺序(3, 5, 1)来返回
    MySQL : instr(str, substr)
    SQLSERVER: charindex(substr, str) 
    返回字符串str 中子字符串的第一个出现位置 
    ltrim(str) 
    返回字符串str, 其引导(左面的)空格字符被删除

(13) resultMap 
   
resultMap负责将SQL查询结果集的列值映射成Java Bean的属性值。

Xml代码

  1. <resultMap class="java.util.HashMap" id="getActionIdAndActionNumber">
  2. <result column="actionId" property="actionId" jdbcType="BIGINT" javaType="long"/>
  3. <result column="count" property="count" jdbcType="INT" javaType="int"/>
  4. </resultMap>
<resultMap class="java.util.HashMap" id="getActionIdAndActionNumber">
<result column="actionId" property="actionId" jdbcType="BIGINT" javaType="long"/>
<result column="count" property="count" jdbcType="INT" javaType="int"/>
</resultMap> 

使用resultMap称为显式结果映射,与之对应的是resultClass(内联结果映射),使用resultClass的最大好处便是简单、方便,不需显示指定结果,由iBATIS根据反射来确定自行决定。而resultMap则可以通过指定jdbcType和javaType,提供更严格的配置认证。

(14) typeAlias

Xml代码

  1. <typeAlias alias="MemberOnlineDuration" type="com.fashionfree.stat.accesslog.model.MemberOnlineDuration" />
  2. <typeAlias>允许你定义别名,避免重复输入过长的名字。
<typeAlias alias="MemberOnlineDuration" type="com.fashionfree.stat.accesslog.model.MemberOnlineDuration" />
<typeAlias>允许你定义别名,避免重复输入过长的名字。

 

(15) remap

Xml代码

  1. <select id="testForRemap" parameterClass="hashMap" resultClass="hashMap" remapResults="true">
  2. select
  3. userId
  4. <isEqual property="tag" compareValue="1">
  5. , userName
  6. </isEqual>
  7. <isEqual property="tag" compareValue="2">
  8. , userPassword
  9. </isEqual>
  10. from
  11. UserInfo
  12. </select>
<select id="testForRemap" parameterClass="hashMap" resultClass="hashMap" remapResults="true">
select
userId
<isEqual property="tag" compareValue="1">
, userName
</isEqual>
<isEqual property="tag" compareValue="2">
, userPassword
</isEqual>
from
UserInfo
</select> 

  此例中,根据参数tag值的不同,会获得不同的结果集,如果没有remapResults="true"属性,iBatis会将第一次查询时的结果集缓存,下次再执行时(必须还是该进程中)不会再执行结果集映射,而是会使用缓存的结果集。
因此,如果上面的例子中remapResult为默认的false属性,而有一段程序这样书写:

Java代码

  1. HashMap<String, Integer> hashMap = new HashMap<String, Integer>();
  2. hashMap.put("tag", 1);
  3. sqlClient.queryForList("testForRemap", hashMap);
  4. hashMap.put("tag", 2);
  5. sqlClient.queryForList("testForRemap", hashMap);
HashMap<String, Integer> hashMap = new HashMap<String, Integer>();
hashMap.put("tag", 1);
sqlClient.queryForList("testForRemap", hashMap);
hashMap.put("tag", 2);
sqlClient.queryForList("testForRemap", hashMap); 

则程序会在执行最后一句的query查询时报错,原因就是iBATIS使用了第一次查询时的结果集,而前后两次的结果集是不同的:(userId, userName)和(userId, userPassword),所以导致出错。如果使用了remapResults="true"这一属性,iBATIS会在每次执行查询时都执行结果集映射,从而避免错误的发生(此时会有较大的开销)。

(16) dynamic标签的prepend

  dynamic标签的prepend属性作为前缀添加到结果内容前面,当标签的结果内容为空时,prepend属性将不起作用。
当dynamic标签中存在prepend属性时,将会把其嵌套子标签的第一个prepend属性忽略。例如:

Xml代码

  1. <sql id="whereSql">
  2. <dynamic prepend="where ">
  3. <isNotNull property="userId" prepend="BOGUS">
  4. userId = #userId#
  5. </isNotNull>
  6. <isNotEmpty property="userName" prepend="and ">
  7. userName = #userName#
  8. </isNotEmpty>
  9. </dynamic>
  10. </sql>
<sql id="whereSql">
<dynamic prepend="where ">
<isNotNull property="userId" prepend="BOGUS">
userId = #userId#
</isNotNull>
<isNotEmpty property="userName" prepend="and ">
userName = #userName#
</isNotEmpty>
</dynamic>
</sql>

此例中,dynamic标签中含有两个子标签<isNotNull>和<isNotEmpty>。根据前面叙述的原则,如果<isNotNull>标签中没有prepend="BOGUS" 这一假的属性来让dynamic去掉的话,<isNotEmpty>标签中的and就会被忽略,会造成sql语法错误。
   注意:当dynamic标签没有prepend属性时,不会自动忽略其子标签的第一个prepend属性。

时间: 2024-08-18 19:44:59

ibatis常用sql的相关文章

自己整理的常用SQL Server 2005 语句、

--创建数据库 create database 数据库 go --打开数据库 use 数据库 --删除数据库 drop database 数据库 Go --创建数据表 create table 数据表 ( 列名1  数据类型1  限定条件(是否是主外键.是否为空), 列名2  数据类型2  限定条件(是否是主外键.是否为空) )go --删除数据表 drop table 数据表 --插入数据 --插入单行数据 insert  into 表名 [(列名1,列名2 )]  values  (‘数据1

ibatis复用SQL片段、引入片段 动态条件增加

1:ibatis复用SQL片段.引入片段  使用[sql]和[include]标签: 通常情况下,你会这样写:xml 代码 <select id="selectItemCount" resultClass="int"> SELECT COUNT(*) AS total FROM items WHERE parentid = 6 select> <select id="selectItems" resultClass=&qu

ibatis 动态SQL

直接使用JDBC一个非常普遍的问题就是动态SQL.使用参数值.参数本身和数据列都是动态SQL,通常是非常困难的.典型的解决办法就是用上一堆的IF-ELSE条件语句和一连串的字符串连接.对于这个问题,Ibatis提供了一套标准的相对比较清晰的方法来解决一个问题,这里有个简单的例子: <select id="getUserList" resultMap="user"> select * from user <isGreaterThan prepend=

sql优化(oracle)- 第二部分 常用sql用法和注意事项

第二部分 常用sql用法和注意事项               1. exists 和 in                             2. union 和 union all                       3. with as  4. order by  5. group by  6. where 和 having  7. case when 和 decode 1.exits和in用法1)说明: 1. exists先对外表做循环,每次循环对内表查询:in将内表和外表

DBA_Oracle DBA常用SQL汇总(概念)

2014-06-20 BaoXinjian DBA常用的SQL汇总 1.监控索引是否使用 alter index &index_name monitoring usage; alter index &index_name nomonitoring usage; select * from v$object_usage where index_name = &index_name; 2.求数据文件的I/O分布 select df.name,phyrds,phywrts,phyblkr

常用sql整理

1. 存储过程 CREATE PROCEDURE [dbo].[bbs_move_createtopic] @fid smallint, @iconid smallint, @curtid INT OUTPUT AS BEGIN INSERT INTO [topics] ...... SET @topicid=SCOPE_IDENTITY() END declare @curtid int exec [createtopic] @fid=@new_fid,@iconid=0, @curtid=

Ubuntu 下安装sqlite3 及常用SQL 语句

安装sqlite3命令如下: 1 sudo apt-get install sqlite3 创建或者打开已有的数据库文件: 1 sqlite3 test.db 进入数据库后,可以进行以下常用SQL语句操作: CREATE TABLE ONT_USER_TABLE( ONT_USER_NAME text PRIMARY KEY, ONT_USER_PWD text NOT NULL, ONT_CREATE_TIME text ); INSERT INTO ONT_USER_TABLE values

常用sql语句及案例

目录 1)基本 2)数学函数 3)rownum 4)分页 5)时间处理 6)字符函数 7)to_number 8)聚合函数 9)学生选课 10)图书馆借阅 基本 --新建表: create table table1( id varchar(300) primary key, name varchar(200) not null); --插入数据 insert into table1 (id,name) values ('aa','bb'); --更新数据 update table1 set id

Oracle数据库常用Sql语句大全

一,数据控制语句 (DML) 部分 1.INSERT  (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, 字段名2, --) VALUES ( 值1, 值2, --); INSERT INTO 表名(字段名1, 字段名2, --)  SELECT (字段名1, 字段名2, --) FROM 另外的表名; 字符串类型的字段值必须用单引号括起来, 例如: 'GOOD DAY' 如果字段值里包含单引号' 需要进行字符串转换, 我们把它替换成两个单引号''. 字符串类型的字段值超过