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

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

resultMap


select返回list集合


<select id="selectLikeName" resultType="com.caq.study.entity.Account">
    select *
    from account
    where name like #{name}
</select>
List<Account> accounts = accountMapper.selectLikeName("%t%");
accounts.forEach(account-> System.out.println(account));

image.png


select封装map


不但可以将mybatis查询的结果封装为集合

也可以封装为map

通过@MapKey注解可以指定key值

@MapKey("name")
Map<String,Object> selectLikeNameMap(String name);
@MapKey("name")
Map<String,Account> selectLikeNameByMap(String name);
<select id="selectLikeNameByMap" resultType="map">
    select *
    from account
    where name like #{name}
</select>
<select id="selectLikeNameMap" resultType="map">
    select *
    from account
    where name like #{name}
</select>

image.png


自定义结果映射规则


对与复杂的查询,我们想让mybaits安装我们自定义的封装规则来封装。Mybatis提供了<ResultMap>来自定义数据的封装规则。

指定主键列的封装规则id定义主键会底层有优化

column:指定哪一列

property:指定对应的javaBean属性

result定义普通列封装规则

如果不指定列的封装规则,则会按照默认规则进行封装

但只要我们写<ResultMap>一般把他们全写上

如下:

<resultMap id="MyEmp" type="com.caq.mybatis.bean.Employee">     
    <id column="id" property="id"/>
    <result column="last_name" property="lastName"/>
    <result column="gender" property="gender"/> 
    <result column="email" property="email"/> 
</resultMap>     
<select id="getEmpById" resultMap="MyEmp">  
    select * from tbl_employee where id = #{id}; 
</select>


级联属性封装结果


1、mapper接口

Account selectByResultMap(Integer id);

2、映射文件

<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>
    <result column="id" property="dept.id"></result>
    <result column="dept_name" property="dept.departName"></result>
</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=开发部))


SQL


这个标签可以用来定义可重用的 SQL 代码片段,以便在其它语句中使用。

参数可以静态地(在加载的时候)确定下来,并且可以在不同的 include 元素中定义不同的参数值。

<sql id="userColumns"> ${alias}.id,${alias}.username,${alias}.password </sql>


<select id="selectUsers" resultType="map">
    select
    <include refid="userColumns">
        <property name="alias" value="t1"/>
    </include>,   
    <include refid="userColumns">
        <property name="alias" value="t2"/>
    </include>
    from some_table t1 cross join some_table t2
</select>

一般我们会把重复的sql字段提取出一个sql,然后不同的语句用这个sql字段的时候我们调这个提取出来的sql即可



相关文章
|
19天前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
26 1
|
2月前
|
SQL Java 数据库连接
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
56 3
|
2月前
|
SQL 缓存 Java
使用MyBatis优化Java持久层操作
使用MyBatis优化Java持久层操作
|
3月前
|
SQL XML Java
后端数据库开发JDBC编程Mybatis之用基于XML文件的方式映射SQL语句实操
后端数据库开发JDBC编程Mybatis之用基于XML文件的方式映射SQL语句实操
57 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 的快速入门与配置)