mybatis嵌套查询和嵌套结果 SSM 框架的集成

本文介绍了MyBatis作为ORM持久层框架的使用,包括其简化数据库交互、XML或注解配置、接口与POJO映射等功能。详细讲解了MyBatis的映射器、SpringAOP的代理模式以及高级查询技巧如模糊查询。接着讨论了MyBatis的嵌套查询,分别阐述了多对一和一对多的情况,并提醒了limit在嵌套查询中的限制。最后,文章探讨了SSM框架的搭建过程,从普通web项目的结构到各个配置文件的设置。
摘要由CSDN通过智能技术生成

mybatis 的运用

1.mybatis的了解

1.1 mybatis是ORM持久层框架,MyBatis是针对数据库交互的一个辅助框架,也是对jdbc做了的简单封装,以xml配置代替Java代码来管理数据库的交互细节.
1.2 MyBatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录.

2.mybatis的映射器

2.1 SpringAOP 面向切面编程 --底层代理模式(额外产出一些子类)

MyBatis基于动态代理机制,让我们无需再编写Dao的实现。

传统Dao接口,现在名称统一以Mapper结尾,还有我们映射器配置文件要和映射器在同一个包.

IDeptDao---->DeptMapper.java—DeptMapper.xml(namespace直接写DeptMapper.java的全限定名)

2.2高级查询
2.2.1 like(模糊查询) 使用concat
<if test="name!=null">
    and name like concat('%',#{name},'%')
</if>
2.2.2 注意转义符的运用
方案1:转义符号
<if test="maxSalePrice != null">
    <!--and saleprice &lt;= #{maxSalePrice}
</if>

方案2:cdata 的区域编译的时候便不会读取
xml 
<![CDATA[
 and saleprice <= #{maxSalePrice}
]]>

3.mybatis的嵌套结果 嵌套查询

3.1 多对一的 嵌套结果 嵌套查询
嵌套查询和嵌套结果
<mapper namespace="cn.itsource._06_manytoone1.EmployeeMapper">

嵌套结果
    <!--<resultMap id="employeeMap" type="employee">
        <id property="id" column="id"></id>
        <result property="name" column="name"></result>
        <result property="age" column="age"></result>
        <association property="department" javaType="Department">
            <id property="id" column="did"></id>
            <result property="name" column="dname"></result>
        </association>
    </resultMap>
    <select id="findAll" resultMap="employeeMap">
        SELECT
        e.id,
        e. NAME,
        e.age,
        d.id did,
        d. NAME dname
    FROM
        t_employee e
    JOIN t_department d ON e.did = d.id
    </select>-->
    嵌套查询 
    <resultMap id="employeeMap" type="employee">
        <id property="id" column="id"></id>
        <result property="name" column="name"></result>
        <result property="age" column="age"></result>
        <association property="department" javaType="Department" column="did" select="findDeptById">
        </association>
    </resultMap>
    <select id="findAll" resultMap="employeeMap">
        SELECT
        e.id,
        e. NAME,
        e.age,
        e.did
        FROM
        t_employee e
    </select>
    <select id="findDeptById" parameterType="long" 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值