`

ibatis常用16条SQL语句

 
阅读更多


原贴地址:http://wapapp.baidu.com/xiaonian8/item/15a6cf4cec4c35a160d7b959

ibatis常用16条SQL语句

(1) 输入参数为单个值
Xml代码 

<delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore"  

parameterClass="long">  

delete from  

MemberAccessLog  

where  

accessTimestamp = #value#  

</delete>  


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


Xml代码 

<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代码 

<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代码 

<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代码 

<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代码 

<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代码 

<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代码 

<delete id="com.fashionfree.stat.accesslog.deleteMemberAccessLogsBefore" parameterClass="long">  

delete from  

MemberAccessLog  

where  

accessTimestamp &lt;= #value#  

</delete>  



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

<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代码 

<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代码 

<sql id=”randomSql”>  

ORDER BY rand() LIMIT #number#  

</sql>  

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



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

<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代码 

<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代码 

<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代码 

<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代码 

<typeAlias alias="MemberOnlineDuration" type="com.fashionfree.stat.accesslog.model.MemberOnlineDuration" />  

<typeAlias>允许你定义别名,避免重复输入过长的名字。 



(15) remap
Xml代码 

<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代码 

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代码 

<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属性。
分享到:
评论

相关推荐

    ibatis常用的sql

    根据提供的文件信息,本文将对ibatis常用的SQL语句进行详细的解析与说明。这些SQL语句主要用于Oracle数据库中,涉及到了删除、插入以及查询等基本操作,并且在ibatis框架中实现了参数化处理。 ### 一、删除操作 ...

    ibatis16个常用sql语句

    iBatis 16个常用SQL语句 iBatis是一个基于Java的持久层框架,提供了一个简洁的方式来访问和操作数据库。在iBatis中,SQL语句是通过XML文件来配置的。下面是16个常用的iBatis SQL语句,涵盖了基本的CRUD(Create、...

    在ibatis日志信息中打印SQL语句的方法(个人总结)

    在使用iBatis(现为MyBatis)作为持久层框架进行开发时,有时我们需要调试SQL语句,以便查看执行的SQL、优化性能或者解决查询问题。本文将详细讲解如何在iBatis日志信息中打印SQL语句,以便更好地理解和优化数据库...

    ibatis常用sql语句

    标题与描述概述的知识点主要集中在iBATIS框架的SQL映射技术上,特别是针对不同类型的输入参数如何在iBATIS中构建SQL语句。以下是对这些知识点的详细展开: ### iBATIS SQL映射技术概览 iBATIS是早期流行的Java持久...

    Ibatis常用sql语句

    根据给定的文件信息,以下是对“Ibatis常用SQL语句”的详细解析,涵盖了一系列Ibatis在数据操作中的应用实例。 ### Ibatis简介 Ibatis是一个支持普通SQL查询、存储过程以及高级映射的优秀持久层框架。Ibatis可以让...

    iBatis的动态SQL语句

    ### iBatis中的动态SQL语句详解 #### 引言 在进行数据库操作时,我们经常需要根据不同的条件构建不同的SQL语句。这种需求在实际开发中极为常见,尤其是在处理复杂的查询逻辑时。iBatis(现在通常被称为MyBatis)...

    ibatis sql 语句的编写

    ### ibatis SQL语句编写详解 #### 一、引言 在软件开发过程中,数据库操作是必不可少的一部分。Ibatis(现称为MyBatis)作为一款优秀的持久层框架,提供了非常灵活的方式来处理SQL语句,使得Java开发者能够更加...

    WAS上log4j日志不能输出(ibatis)sql语句解决办法[借鉴].pdf

    WAS 上 log4j 日志不能输出(ibatis)sql 语句解决办法 在部署到 WAS 服务器上的 CMSII 系统中,ibatis 的 sql 语句不能输出日志的问题。解决该问题需要改变 WAS 的默认 LogFactory 实现类,使其使用 log4j 框架下...

    打log4j日志-ibatis的sql输出

    在默认情况下,Ibatis并不会自动打印执行的SQL语句,但通过配置,我们可以使Ibatis在运行时输出SQL,这对于调试和性能分析非常有帮助。 要启用Ibatis的SQL日志记录,你需要在Ibatis的配置文件(通常为`mybatis-...

    将SQl语句转换成Ibatis之Xml文件语句

    用Ibatis时,配置sql语句时候 如果直接从sql里面把语句拷出来,玩玩格式不严谨,我写了这个工具来帮助我们格式化sql语句

    iBatis.net使用动态sql语句

    因为要下载其它的文件,所以从网站复制了一些其它的资源进行上传。但是这个资源是相当有用的。这里感谢之前总结相关技术的人员。谢谢

    sql语句中用问号代替参数

    在SQL语句中,使用问号(`?`)作为参数占位符是一种常见的做法,尤其是在编程语言如Java中与数据库交互时。这种方式被称为预编译语句或参数化查询,它具有重要的安全性和性能优势。 ### SQL参数化查询的概念 参数化...

    ibatis sql语句对条件中特殊字符% # 处理

    ### ibatis SQL语句对条件中特殊字符% # 处理 在开发过程中,经常会遇到SQL查询时需要处理字符串中的特殊字符的情况。特别是在使用类似`LIKE`这样的操作符时,如果用户输入的数据中含有`%`、`_`或`#`等特殊字符,...

    ibatis动态SQL标签用法

    iBatis提供了动态SQL片段的功能,可以将SQL语句拆分成小的、独立的片段,然后根据不同的条件组合这些片段生成最终的SQL语句。这可以提高代码的可重用性和灵活性。 例如,在上面的代码中,我们定义了三个动态SQL片段...

    ibatis中使用安全的拼接语句,动态查询,大于、小于、等于.doc

    在 iBatis 中,使用动态 SQL 可以生成安全的拼接语句,避免 SQL 注入攻击。例如,在上面的示例代码中,我们使用 `&lt;dynamic&gt;` 元素来定义动态 SQL 语句,在其中使用 `&lt;isNotNull&gt;`、`&lt;isGreaterThan&gt;`、`&lt;isLessThan&gt;...

    查看ibatis后台sql

    通过java程序查看ibatis配置文件中的sql语句(注:无法查看变量值)

    根据MyBatis或iBatis的SQLMapper文件反向生成数据库表

    根据MyBatis或iBatis的SQLMapper文件解析生成数据库表,通常是指通过解析MyBatis或iBatis的SQLMapper文件中的SQL语句,然后根据这些SQL语句来生成对应的数据库表结构。这样的需求可能源于需要将已有的SQLMapper文件...

    使用P6spy打印ibatis执行的SQL语句

    本文将详细探讨如何使用P6Spy来打印iBatis(现为MyBatis)执行的SQL语句,以便进行性能分析和调试。 首先,我们需要了解P6Spy的工作原理。P6Spy通过替换JDBC驱动,将自己插入到应用程序和数据库之间,监听所有的SQL...

    ibatis2包和能显示执行的sql语句的ibatis2.jar

    Ibatis2是一款经典的Java持久层框架,它提供了一种将SQL语句与Java代码分离的解决方案,使得数据库操作更加灵活且易于维护。Ibatis2的核心是SqlMapConfig.xml配置文件,其中包含了数据源、事务管理以及SqlMap的定义...

Global site tag (gtag.js) - Google Analytics