ibatis常用16条SQL语句(转)

来源:互联网 发布:qq群 淘宝客机器人 编辑:程序博客网 时间:2024/05/18 00:18

(1)输入参数为单个值

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

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

 

Xml代码  收藏代码
  1. <</span>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. </</span>insert>   

 

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

Xml代码  收藏代码
  1. <</span>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 #start#   
  11. and accessTimestamp <= #end#   
  12. group by actionId   
  13. </</span>select>  

 

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

   

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

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

 

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

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

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

 

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

Xml代码  收藏代码
  1. <</span>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 >= #start#   
  9. and accessTimestamp #end#   
  10. and actionId in $actionIdString$   
  11. </</span>select>  

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

 

    (7)分页查询(pagedQuery)

   

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

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


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

    1.将大于号、小于号写为: > <如: 

Xml代码  收藏代码
  1. <</span>delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore" parameterClass="long">   
  2. delete from   
  3. MemberAccessLog   
  4. where   
  5. accessTimestamp <= #value#   
  6. </</span>delete>   

 

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

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

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

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

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

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

(10)随机选取记录

Xml代码  收藏代码
  1. <</span>sql id=”randomSql”>   
  2. ORDER BY rand() LIMIT #number#   
  3. </</span>sql>   

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

 

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

Xml代码  收藏代码
  1. <</span>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   
  9. WHERE a.questionCategoryId q.questionCategoryId   
  10. GROUP BY a.answererId   
  11. ORDER BY a.answererCategoryId   
  12. </</span>sql>  

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

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

    ①MySQL: 

Xml代码  收藏代码
  1. <</span>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. </</span>sql>   

    

②SQLSERVER:

Xml代码  收藏代码
  1. <</span>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. </</span>sql>  

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

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

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

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


(14)typeAlias

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

 

(15)remap

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

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

Java代码  收藏代码
  1. HashMap hashMap new HashMap();   
  2. hashMap.put("tag"1);   
  3. sqlClient.queryForList("testForRemap"hashMap);   
  4. hashMap.put("tag"2);   
  5. sqlClient.queryForList("testForRemap"hashMap);   

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

(16)dynamic标签的prepend

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

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

  

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


转自:

http://javacrazyer.iteye.com/blog/1135561

转载请说明转载地址.

0 0
原创粉丝点击