mybatisSQL映射文件

实现条件查询

mybatis真正强大之处在于SQL映射语句,使用SQL映射文件配置可减少50%以上的代码量,并且mybatis专注于SQL


SQL映射文件几个顶级元素配置:

(1)mapper:映射文件的根元素节点,只有一个属性namespace(命名空间)

<1>用于区分不同的mapper,全局唯一 

<2>绑定dao接口,即面向接口编程,当namespace绑定某一接口之后,可以不用写该接口的实现类,mybatis会通过接口的完整限定名查找到对应的mapper配置执行SQL语句,因此namespace的命名必须要跟接口同名   
(2)cache:配置给定命名空间的缓存

(3)cache-ref:从其他命名空间引用缓存配置 

(4)resultMap:用来描述数据库结果集的对应关系 

(5)sql:可以重用的SQL块,也可以被其他语句引用 

(6)insert:映射插入语句 

(7)update:映射更新语句 

(8)delete:映射删除语句 

(9)select:映射查询语句 

使用select完成单条件/多条件查询
单条件查询


<!--根据用户名称查询用户列表(模糊查询)  -->
<select id="getUserList"  parameterType="string"   resultType="User">
SELECT * FROM smbms_user
             WHERE `userName` LIKE CONCAT('%',#{uName},'%')
</select>

注意参数的传递使用#{参数名}它告诉mybatis生成preparedStatement参数,对于JDBC,该参数会被标识为“?”。
讲解select元素中属性和mybatis配置文件的属性:

    >id:命名空间的唯一的标识符,可以被用来引用的这条语句(一般对应接口的方法名)
    >parameterType:表示查询语句传入参数的类型完全限定名或别名。它支持基本数据类型和复杂数据类型
    >resultType:查询语句返回结果类型的完全限定名或别名,别名的使用方式与parameterType一致。

多条件条件查询


<select id="getUserList"  parameterType="User"   resultType="User">
SELECT * FROM smbms_user
             WHERE `userName` LIKE CONCAT('%',#{uName},'%') AND `userRole`=#{uRole}
</select>

parameterType使用了复杂数据类型,把条件参数封装成User对象进行入参,是对User对象的属性进行赋值;

mybatis传入参数类型可以是java基础数据类型,但是只适用于一个参数的情况,通过#{参数名}即可获取传入的值,若是多参数入参,需要复杂数据类型来支持,包括java实体类,Map,通过#{属性名}或#{Map的key}来获取传入的参数值


使用resultMap完成查询结果的展现

使用resultMap做自定义结果映射,字段名可以不一致,并且还可以指定要显示的列,比较灵活,应用广泛。

<select id="getUserList"  parameterType="User"   resultMap="userList">
SELECT u.*,r.roleName FROM smbms_user u,smbms_role r
             WHERE `userName` LIKE CONCAT('%',#{uName},'%') AND `userRole`=#{uRole}  AND u.userRole=r.id 
</select>

<resultMap type="User" id="userList">
        <result property="id" column="id"/>
        <result property="userCode" column="userCode"/>
        <result property="userName" column="userName"/>
</resultMap>

resultMap元素用来描述如何将结果集映射到java对象,特别是当数据库的字段名与POJO中的属性名不一致的情况下,比如角色名 字段名column是roleName,而user对象的属性名则为userRoleName,此时就需要做映射

     >id属性:唯一标识,此id值用于select元素resultMap属性的引用     
     >type属性:表示该resultMap的映射结果类型
     >result子节点:用于标识一些简单属性,其中column属性表示从数据库中查询的字段名,property则表示查询出来的字段对应的值赋给实体对象的哪个属性。

1.resultType

resultMap直接表示返回类型,包括基础数据类型和复杂数据类型

2.resultMap

resultMap则是对外部resultMap定义的引用,对应外部的resultMap的id,表示返回结果映射到哪一个resultMap上,应用场景是:数据库字段信息与对象属性不一致或者需要做复杂的联合查询以便自由控制映射结果

在mybatis的select元素中,resultMap和resultType本质上是一样的,都是map数据结构,但需要明确一点,resultType属性和resultMap属性绝对不能同时存在,只能二者选其一。

实现增删改操作

使用insert完成增加操作


<!--增加用户  -->
<insert id="add" parameterType="User">
    INSERT INTO smbms_user(userCode,userName,)VALUES(#{userCode},#{userName})   
</insert>

User对象入参,返回值为int类型,即返回执行SQL影响的行数
insert元素的属性与select元素类似,不一一赘述。


对于增删改等数据更新操作,需注意两点
1、该类型的操作本身默认返回执行SQL影响的行数,所以dao层的接口方法的返回值一般设置为int类型,最好不要返回Boolean型
2、insert、update、delete元素中均没有resultType属性,只有查询操作需要对返回结果类型(resultType/resultMap)进行相应的指定。


使用update完成修改操作

<update id="modify" parameterType="User">
        UPDATE smbms_user SET userPassword=#{userPassword} WHERE id=#{id}
</update>

使用@param注解实现多参数入参
接口方法:

public  int  updatePwd(@Param("id")Integer id,@Param("userPassword")String pwd);

mapper.xml

<update id="updatePwd">
        UPDATE smbms_user SET userPassword=#{userPassword} WHERE id=#{id}
</update>

在mybatis中参数入参,何时需要封装成对象入参,何时又需要使用多参数入参?
一般情况下,超过4个以上的参数最好封装成对象入参(特别是在常规的增加和修改操作时,字段较多,封装成对象比较方便),需注意,当参数为基本数据类型是,不管是多参数入参,还是单独的一个参数入参,都需要使用@param注解来进行参数的传递。


使用delete完成删除操作(@param)

<delete id="deleteUserById" parameterType="Integer">
        DELETE FROM smbms_user WHERE id=#{id}
</delete>

实现高级结果映射 /自动映射级别/mybatis缓存

association

association:映射到Javabean的某个“复杂类型”类型,比如Javabean类,即Javabean内部嵌套一个复杂数据类型属性,属于复杂类型查询。association仅处理一对一的关联关系


public class User {

    private Integer id; //id 
    private String userCode; //用户编码
    private String userName; //用户名称
    private String userPassword; //用户密码
    private Role role;//用户角色
    //省略getter和setter方法
}
--------------------------------------------------------------------------
public List<User> getUserListByRoleId(@Param("userRole") Integer roleId);
--------------------------------------------------------------------------
    <select id="getUserListByRoleId" parameterType="Integer" resultMap="userRoleResult">
        SELECT u.*,r.id as r_id ,r.roleCode,r.roleName FROM smbms_user u,smbms_role r
         WHERE u.userRole=#{userRole} AND u.userRole=r.id
    </select>
    <resultMap type="User" id="userRoleResult">
        <id property="id" column="id"/>
        <result property="userCode" column="userCode"/>
        <result property="userName" column="userName"/>
        <result property="userRole" column="userRole"/>
        <association property="role" javaType="Role" resultMap="roleResult"></association>
    </resultMap>
    <resultMap type="Role" id="roleResult">
            <id property="id" column="r_id"/>
            <result property="roleCode" column="roleCode"/>
            <result property="roleName" column="roleName"/>
    </resultMap>

简单分析association的属性:

> javaType:完整java类名或者别名。若映射到一个Javabean,则mybatis通常会自行检测到其他类型;若映射到一个HashMap,则应该明确指定Javatype,类确保所需行为,此处为role
> property:映射数据库列的实体对象的属性。此处为在User里定义的属性:role
>id
>result
     >property:映射数据库列的实体对象的属性。此处为role的属性
     >column:数据库列名或别名

在做结果映射的过程中,需要注意:要确保所有的列名都是唯一且无歧义的。


collection
collection元素的作用和association元素作用差不多一样,非常类似,只不过这个属性是一个集合列表,即Javabean内部嵌套一个复杂数据类型(集合)属性。


public class User {

    private Integer id; //id 
    private String userCode; //用户编码
    private String userName; //用户名称
    private String userPassword; //用户密码
    private Role role;//用户角色
    private List<Address> addressList;//用户地址列表
    //省略getter和setter方法
}
--------------------------------------------------------------------------
public class Address {

     private Integer id;//主键id
     private String postCode;//邮编
     private String contact;//联系人
     private String addressDesc;//地址
}
--------------------------------------------------------------------------
public  List<User> getAddressListByUserId(@Param("id") Integer userId);
--------------------------------------------------------------------------
    <select id="getAddressListByUserId" parameterType="Integer" resultMap="userAddressResult">
        SELECT u.*,a.id as a_id,a.contact,a.addressDesc,a.postCode,a.tel  
        FROM smbms_user u,smbms_address a WHERE u.id=a.userId and u.id=#{id}
    </select>
    <resultMap type="User" id="userAddressResult">
        <id property="id" column="id"/>
        <result property="userCode" column="userCode"/>
        <result property="userName" column="userName"/>
        <collection property="addressList" ofType="Address" resultMap="adddressResult"></collection>
    </resultMap>
    <resultMap type="Address" id="adddressResult">
            <id property="id" column="a_id"/>
            <result property="contact" column="contact"/>
            <result property="addressDesc" column="addressDesc"/>
            <result property="postCode" column="postCode"/>
            <result property="tel" column="tel"/>

    </resultMap>

简单分析collection的属性:

> ofType:完整java类名或者别名。即集合所包含的类型,此处为Address
> property:映射数据库列的实体对象的属性。此处为在User里定义的属性:addressList

collection的子元素与association基本一致


resultMap自动映射级别
修改mybatis-config.xml代码

<settings>
        <setting name="autoMappingBehavior" value="NONE"/>
</settings>

自动映射的三个级别

>NONE:禁止自动匹配
>RARTIAL(默认):自动匹配所有属性,有内部嵌套(association,collection)的除外
>FULL:自动匹配所有

mybatis缓存

1、一级缓存
一级缓存是基于PerpetualCache(mybatis自带)的HashMap本地缓存,作用范围为session域内,当session flush或close之后,该session中所有的cache就会被清空
2、二级缓存
二级缓存就是global caching 它超出session范围之外,可以被所有Sqlsession共享,开起它只需要在没有把他的核心配置文件settings中设置即可

一级缓存缓存的是SQL语句,二级缓存缓存的是结果对象

3、二级缓存的配置
>mybatis的全局cache配置,需要在mybatis-config.xml的settings设置
<settings>
        <setting name="cacheEnabled" value="true"/>
    </settings>
>在mapper文件中设置缓存,默认情况下是没有开起缓存的,注意global caching的作用域是针对mapper的namespace而言的,只有在此namespace内的查询才能共享这个cache

>在mapper文件配置支持cache后,如果需要对个别查询进行调整,可以单独设置cache。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值