IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> SSM框架复习巩固 -> 正文阅读

[Java知识库]SSM框架复习巩固

mybatis复习第三天:mybatis的多表查询? 延迟加载问题? mybatis缓存

一.mybatis多表查询;

1.一对一关系

例如:

user 用户表 和userCard ?身份证表

一个用户只有一个(对应)身份证,同样一个身份证对应一个用户,这就是一对一关系。

xml映射配置文件如下如下:

<!--    结果集映射    配置实体类与数据库表的映射关系  数据库字段与实体类属性的映射-->
    <resultMap id="userMap" type="com.swlz.domain.User">
        <id column="id" property="id"></id>
        <result column="name" property="name"></result>
        <result column="age" property="age"></result>
        <result column="sex" property="sex"></result>
        <result column="address" property="address"></result>
<!--        完成一对一关联对象映射的标签-->
        <association property="userCard" javaType="UserCard">
            <id  column="ucid"  property="id"></id>
            <result column="uid" property="uid"></result>
            <result column="cardNum" property="cardNum"></result>
        </association>
<!--   <select id="findAll" resultType="com.swlz.domain.UserAndCard">
    SELECT * FROM USER u LEFT JOIN usercard uc ON u.id=uc.`UID`;
   </select>-->
    <select id="findAll" resultMap="userMap">
     SELECT u.*,uc.`ID` ucid,uc.`UID`,uc.`cardNum` FROM USER u LEFT JOIN usercard uc ON u.`id`=uc.`UID`;
   </select>

2.一对多(多对一)关系

例如:

用户?1 ?---- ??订单 n

一个用户可以会有多个订单,一个订单只能对应一个用户。

用户?1 ??---- ?账户 n account

一个用户可能会开多个账户,也就是说一个用户会有多个账户。

xml映射配置文件如下:

<resultMap id="userAccountMap" type="com.swlz.domain.User">
        <id column="id" property="id"></id>
        <result column="name" property="name"></result>
        <result column="age" property="age"></result>
        <result column="sex" property="sex"></result>
        <result column="address" property="address"></result>
<!--完成 一对多或者多对多 关联对象的封装   property 属性  User类中有的属性    column字段  数据库中有的字段-->
       <collection property="accountList" javaType="java.util.List" ofType="Account">
<!--因为这里id和user表里面的id字段重名了,所以会有冲突,会当成user表中的id打印出来,
                                    所以我们要为account表中的id起一个别名来区分user表中的id和account表中的id-->
           <id column="aid" property="id"></id>
           <result column="uid" property="uid"></result>
           <result column="money" property="money"></result>
       </collection>
    </resultMap>
 <select id="findUserAndAccount" resultMap="userAccountMap">
SELECT u.*,a.`ID` aid,a.`UID`,a.`MONEY` FROM USER u LEFT JOIN account a ON u.`id`=a.`UID`;  
 </select>

3.多对多关系

例如:老师???????学生?

一个老师可能会教多个(对应)学生,一个学生可能也会(对应)有多个老师

用户???????角色

一个用户可能会(对应)多个角色,一个角色可能也会(对应)多个用户

xml映射配置文件如下:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.swlz.dao.UserDaoMapper">
    <resultMap id="userRoleMap" type="com.swlz.domain.User">
        <id column="id" property="id"></id>
        <result column="name" property="name"></result>
        <result column="age" property="age"></result>
        <result column="sex" property="sex"></result>
        <result column="address" property="address"></result>
        <collection property="roleList" javaType="java.util.List" ofType="Role">
            <id column="rid" property="id"></id>
            <result column="role_name" property="role_name"></result>
            <result column="role_desc" property="role_desc"></result>
        </collection>
    </resultMap>
<select id="findAll" resultMap="userRoleMap">
   SELECT u.*,r.`ID` rid,r.`ROLE_NAME`,r.`ROLE_DESC` FROM USER u LEFT JOIN user_role ur ON u.id=ur.`UID` LEFT JOIN role r ON ur.`RID`=r.id;
</select>
</mapper>

二.mybatis的延迟加载

mybatis延迟加载(针对多表查询)

立即加载

查询一个对象的时候,立马的把对象关联的对象查询出来

延迟加载

查询一个对象的时候,关联对象先不查询,什么时候使用对象,什么时候再查询对象

会产生一个n+1的问题?

查询用户的时候要查询用户关联的账号

账号信息是什么时候时候,什么时候查询

<!--配置参数-->

????<settings>

????????<!--开启Mybatis支持延迟加载-->

????????<setting name="lazyLoadingEnabled" value="true"/>

????????<setting name="aggressiveLazyLoading" value="false"></setting>

????</settings>

一对一或者多对一的时候使用??立即加载

一对多?或者多对多查询的时候使用??延迟加载

?配置如下:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.swlz.dao.UserDaoMapper">
<!--    结果集映射    配置实体类与数据库表的映射关系  数据库字段与实体类属性的映射-->
    <resultMap id="userMap" type="com.swlz.domain.User">
        <id column="id" property="id"></id>
        <result column="name" property="name"></result>
        <result column="age" property="age"></result>
        <result column="sex" property="sex"></result>
        <result column="address" property="address"></result>
<!--(参数)column="id"这个是指根据用户的id字段去查询出用户对应的账户 ,javaType="java.util.List"(这个是java返回值类型List集合)
    ofType="Account"这个是返回值类型(泛型),根据这个com.swlz.dao.AccountDaoMapper.findAccountByUid-->
        <collection property="accountList" javaType="java.util.List" ofType="Account" column="id" select="com.swlz.dao.AccountDaoMapper.findAccountByUid">

        </collection>
    </resultMap>
<!--   <select id="findAll" resultType="com.swlz.domain.UserAndCard">
    SELECT * FROM USER u LEFT JOIN usercard uc ON u.id=uc.`UID`;
   </select>-->
    <select id="findAll" resultMap="userMap">
       select * from user;
   </select>
    <select id="findUserById" parameterType="java.lang.Integer" resultType="User">
        select * from user where id=#{id};
    </select>
</mapper>
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.swlz.dao.AccountDaoMapper">
    <select id="findAccountByUid" resultType="Account" parameterType="java.lang.Integer">
        SELECT * FROM account WHERE  uid=#{uid};
    </select>
</mapper>

三.mybatis缓存

1. 一级缓存

特点: 数据是缓存在sqlsession中,通过同一个sqlsession对象去获取数据的时候,第一次从数据库中获取的数据会缓存到sqlsession中,下次再获取相同数据的时候,直接从sqlsession中获取

会话级别的缓存??mybatis的内置缓存

?操作数据库的这次会话(对话)

会话级别的缓存,只有在当前这个sqlSession中才会生效。

在同一个SqlSession之间是可以共享缓存的数据的。

一级缓存清空的情况

1. 执行了增删改操作之后 ,一级缓存的数据自动清空

2. 直接关闭sqlSession或者提交事物

3. 手动调用 sqlSession.clearCache();

2. 二级缓存

特点:mybatis的二级缓存数据是缓存在SqlSessionFactory(一个项目只会创建一个SqlSessionFactory对象)? ? ?

特点:mybatis的二级缓存数据是缓存在SqlSessionFactory(一个项目只会创建一个SqlSessionFactory对象) ? mapper级别的缓存??

每一张数据库表都对应一个mapper,每一张表的数据都缓存在对应的mapper缓存块中,那些缓存但是保存在SqlSessionFactory中

mybatis的二级缓存数据是缓存在SqlSessionFactory

当执行了增删改操作时候,会自动清空当前mapper中的缓存数据。

今日学习感受:既然选择了这条路,义无反顾的坚持下去把!相信,你越努力,它会让你越幸运,你想要的也会随之即来。这就是你付出多少,你就会回报多少,当然有时候你付出也不会有回报,但是IT行业,java后端,只要你肯努力,我敢上一定会有回报,你一定要坚持下去,加油。最后一句话:时间就是金钱!

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-12-24 18:20:30  更:2021-12-24 18:21:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 7:48:29-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码