Mybatis快速入门--映射文件(四)(优化版)

简介: Mybatis快速入门--映射文件(四)(优化版)

association


使用association定义关联的单个对象的封装规则

1、mapper接口


Account selectByResultMap(Integer id);

2、映射文件

property指定那个对象是联合的对象, javaType指定联合对象的类型(不能省略)


<resultMap id="resultMapTest" type="com.caq.study.entity.Account">
    <id column="id" property="id"></id>
    <result column="name" property="name"></result>
    <result column="money" property="money"></result>
    <association property="dept" javaType="com.caq.study.entity.Dept">
        <id column="id" property="id"></id>
        <result column="dept_name" property="departName"></result>
    </association>
</resultMap>
<select id="selectByResultMap" resultMap="resultMapTest">
    SELECT
        account.`id`,
        account.`name`,
        account.`money`,
        depart.`id`,
        depart.`dept_name`
    FROM
        `account`
            LEFT JOIN `depart` ON account.d_id = depart.id
    WHERE
        account.id = #{id}
</select>

3、测试


@Test
public void testResultMap() throws IOException {
    SqlSession sqlSession = getSqlSessionFactory().openSession();
    AccountMapper accountMapper = sqlSession.getMapper(AccountMapper.class);
    Account account = accountMapper.selectByResultMap(1);
    System.out.println(account);
    sqlSession.commit();
    sqlSession.close();
}
Account(id=1, name=tom, money=5000.00, dept=Dept(id=1, departName=开发部))

上面这种查询方式可以理解为嵌套查询


分布查询


相当于查询account表的所有数据,查询到所有数据后,

再把和Dept有关联的字段传给DeptMapper接口

通过这种方式实现分布查询


mapper接口:
Account selectAssociate(Integer id);
映射文件:
<resultMap id="AsscociateTest" type="com.caq.study.entity.Account">
    <id column="id" property="id"></id>
    <result column="name" property="name"></result>
    <result column="money" property="money"></result>
    <association property="dept"
                 select="com.caq.study.mapper.DepartMapper.getDeptById"
                 column="d_id">
    </association>
</resultMap>
<select id="selectAssociate" resultMap="AsscociateTest">
    SELECT * from account where id = #{id}
</select>


mapper接口:
Dept getDeptById(Integer id);
映射文件:
<select id="getDeptById" resultType="com.caq.study.entity.Dept">
    select id,dept_name departName from depart where id = #{id}
</select>

测试


@Test
public void testAssociate() throws IOException {
    SqlSession sqlSession = getSqlSessionFactory().openSession();
    AccountMapper accountMapper = sqlSession.getMapper(AccountMapper.class);
    Account account = accountMapper.selectAssociate(1);
    System.out.println(account);
    System.out.println(account.getDept());
    sqlSession.commit();
    sqlSession.close();
}
Account(id=1, name=tom, money=5000.00, dId=null, dept=Dept(id=1, departName=开发部))
Dept(id=1, departName=开发部)


延迟加载


上面的我们写的查询有什么问题呢?

就是部门信息我们无论需不需要它都会查询,这样很浪费资源

怎么解决这个问题呢?

==延迟加载!==

分段查询的基础上在mybatis主配置文件加上两个配置

显示的指定每个我们需要更改的配置的值,即使他是默认的

log4j

做延迟加载前,为了看效果我们加上log4j查看控制台的日志

1、使用Log4j需要导入相关的jar包 (这里是Maven中的依赖包):


<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>

2、使用log4j


<settings>
    <!--标准日志工厂实现-->
    <!--<setting name="logImpl" value="STDOUT_LOGGING"/>-->
    <!---Log4j工厂实现-->
    <setting name="logImpl" value="LOG4J"/>
</settings>

3、log4j.properties


log4j.rootLogger=debug, stdout, R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=./log/Gosion.log
log4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=5
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n

测试延迟加载

==未开启==

image.png

==开启==


<settings>
    <setting name="logImpl" value="LOG4J"/>
    <setting name="jdbcTypeForNull" value="NULL"/>
    <setting name="lazyLoadingEnabled" value="true"/>
    <setting name="aggressiveLazyLoading" value="false"/>
</settings>

image.png



相关文章
|
7天前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
15 1
|
2月前
|
SQL Java 数据库连接
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
51 3
|
2月前
|
SQL 缓存 Java
使用MyBatis优化Java持久层操作
使用MyBatis优化Java持久层操作
|
3月前
|
SQL XML Java
后端数据库开发JDBC编程Mybatis之用基于XML文件的方式映射SQL语句实操
后端数据库开发JDBC编程Mybatis之用基于XML文件的方式映射SQL语句实操
54 3
|
3月前
|
Java 数据库连接 API
后端开发之用Mybatis简化JDBC的开发快速入门2024及数据库连接池技术和lombok工具详解
后端开发之用Mybatis简化JDBC的开发快速入门2024及数据库连接池技术和lombok工具详解
48 3
|
2月前
|
SQL 缓存 Java
使用MyBatis优化Java持久层操作
使用MyBatis优化Java持久层操作
若依修改,集成mybatisplus报错,若依集成mybatisplus,总是找不到映射是怎么回事只要是用mp的方法就找报,改成mybatisPlus配置一定要改
若依修改,集成mybatisplus报错,若依集成mybatisplus,总是找不到映射是怎么回事只要是用mp的方法就找报,改成mybatisPlus配置一定要改
|
2月前
|
XML Java 数据格式
支付系统----微信支付20---创建案例项目--集成Mybatis-plus的补充,target下只有接口的编译文件,xml文件了,添加日志的写法
支付系统----微信支付20---创建案例项目--集成Mybatis-plus的补充,target下只有接口的编译文件,xml文件了,添加日志的写法
|
2月前
|
Java 数据库连接 Maven
Private method ‘getVideoList()‘ is never used,mybatis必须指定Mapper文件和实体目录,在参考其他人写的代码,要认真分析别人的代码,不要丢失
Private method ‘getVideoList()‘ is never used,mybatis必须指定Mapper文件和实体目录,在参考其他人写的代码,要认真分析别人的代码,不要丢失
|
3月前
|
Java 数据库连接 Apache
JavaWeb基础第二章(Maven项目与MyBatis 的快速入门与配置)
JavaWeb基础第二章(Maven项目与MyBatis 的快速入门与配置)