SqlMap的配置是iBatis中应用的核心:

1、命名空间:  <sqlMap namespace="mune">,在此空间外要引用此空间的元素,则需要加上命名空间名。 (在三层架构中一般在持久层调用的时候通过命名空间名访问)

2、实体的别名:<typeAlias type="java.util.HashMap" alias="hmap"/>  也可以是自己写的实体类  <typeAlias alias="mune" type="com.pur.mune"/>

 

 

3、SQL入参parameterClass  插入语句入参:parameterClass="类别名"  来设定。  查询语句入参:可以设定类别名,也可以设定为map,也可以设定为iBatis支持的原生类型(比如string、int、long等),当只有一个原生类型入参时,则在SQL中用value关键字来引用。比如:    <select id="getById"  parameterClass="hamp“ resultMap="result_base">

 

 

        select * from customer where id = #value#

    </select>    map是最强大的入参方式,任何入参方式都可以转换为这种入参方式,因为iBatis仅接受一个入参,当几个参数分布在不同对象中的时候,将这些对象的属性(或者对象本身put)到map中,然后一次传递给sql语句是非常有效。可以自己写一个将对象或者对象集合转换为map的工具(我已经实现一个了)。    另外,map的中的元素(比如pobj)是个复杂对象,则还可以在SQL中以#pobj.protyename#的格式来引用其中内嵌的属性。当然不推荐这么干。

 

 

4、返回值参数类型      返回值参数也同样有两种类型,一种是对象类型resultClass="Account",一种是resultMap="AccountResult"。这两种类型的选择常常会令人迷惑不解,一言明其理:当结果集列名和类属性名完全对应的时候,则应该使用resultClass来指定查询结果类型。当然有些列明不对应,可以在sql中使用as重命名达到一致的效果。 当查询结果列名和类属性名对应不上的时候,应该选择resultMap指定查询结果集类型。否则,则查询出来填充的对象属性为空(数字的为0,对象的为null)。 但是实际上resultMap是对一个Java Bean的映射,需要先定义xml的映射后,才可以引用,例如:    <resultMap id="muneAccountResult" class="mune">

 

 

        <result property="id" column="ACC_ID"/>
        <result property="firstName" column="ACC_FIRST_NAME"/>
        <result property="lastName" column="ACC_LAST_NAME"/>
        <result property="emailAddress" column="ACC_EMAIL"/>

    </resultMap>    resultMap映射的结果的目的就是要将查询的结果集绑定到映射对象的属性上。    不管使用哪种返回值参数类型,其最终目的就是要把每条记录映射到一个类的对象或者对象集合上,如果有某个类属性映射不上,则在得到的这个对象或对象集合中这个属性为空。映射的属性可以是表与实体中的一部分。不要同时使用两种返回值参数类型,这样只会令人迷惑。

5、SQL中参数的引用     SQL中引用parameterClass的参数有三种方式:     iBatis内置支持的类型,比如int、string,使用#value#来引用,这个value是关键字,不可变。     map类型的参数,使用#keyName#来引用,keyName为键名。     复杂对象的参数,使用#propertyName#来引用,propertyName类属性的名字。 

6、模糊查询中参数的引用    模糊查询是针对字符串而言的,如果遇到两个单引号要包含一个参数,则不能再用#来引用变量了,而应该改为$,比如:'%$varName$%',当然,也可以使用 '%' || #varname# || '%' 来绕过此问题。

7、SQL片段       可以通过<sql id="sql_xxx">...</sql>定义SQL片段,然后<include refid="sql_xxx"/>来在各种语句中引用。达到服用目的,

 

 

8、动态SQL      可以通过使用动态SQL来组织灵活性更大的更通过的SQL,这样极大减少了编码量,是iBatis应用的第二大亮点。     比如:一个动态的where条件                <dynamic prepend="where">

 

 

                        <isNotEmpty prepend="and" property="$$$$$">
                                $name like '%'|| #$name# ||'%'
                        </isNotEmpty>
                        <isGreaterThan prepend="and" property="$$$$$" compareValue="$$$number">
                                $code like '%'|| #$code# ||'%'
                        </isGreaterThan>

                </dynamic>     当然,prepend表示链接关键字,可以为任何字符串,当为sql关键字时,iBatis自动判断是否应该添加该关键字。该语法也很简单,关键是要会用心思考组织动态SQL。    这里面有一点要注意:区别<isNotEmpty>和<isNotNull>区别,当为空空串时<isNotEmpty>返回true,当为空串时<isNotNull>返回真。