Mybatis进阶教程

简介: 前言接着上一篇Mybatis入门继续,上一篇主要演示了Mybatis的基本操作,对数据库的增删改查,但是在实际项目中用到的Mybatis知识点要远多于这些基本操作,这篇将演示一些Mybatis的更加常用的用法。

前言

接着上一篇Mybatis入门继续,上一篇主要演示了Mybatis的基本操作,对数据库的增删改查,但是在实际项目中用到的Mybatis知识点要远多于这些基本操作,这篇将演示一些Mybatis的更加常用的用法。

知识点汇总

新建项目,基本环境都如上篇,Maven的pom.xml中添加jUnit依赖。

Insert获取主键的值

Mapper.xml的Insert节点添加useGeneratedKeys,keyProperty即可。

KeyProperty:(仅对 insert 和 update 有用)唯一标记一个属性,MyBatis 会通过 getGeneratedKeys 的返回值或者通过 insert 语句的 selectKey 子元素设置它的键值,默认:unset。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。

UseGeneratedKeys:仅对 insert 和 update 有用)这会令 MyBatis 使用 JDBC 的 getGeneratedKeys 方法来取出由数据库内部生成的主键(比如:像 MySQL 和 SQL Server 这样的关系数据库管理系统的自动递增字段),默认值:false。

Mybaitis 入门教程的项目, Mapper.xml文件中
修改内容为下:

    <insert id="insertBlog" parameterType="Blog"
            keyProperty="id"
            useGeneratedKeys="true"
    >
        INSERT INTO Blog (id,title) VALUES (#{id},#{title})
    </insert>

此时数据库内容:

img_9b64f329a77866add20099a8197c4b5e.png
程序运行前数据库内容

测试程序:

 @Test
    public void test1(){
        InputStream inputStream = null;
        SqlSession sqlSession = null;
        try {
            inputStream = Resources.getResourceAsStream("mybatis-config.xml");
            SqlSessionFactory mSqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            sqlSession = mSqlSessionFactory.openSession();
            Blog blog = new Blog("获取主键的值");
            sqlSession.insert("me.aihe.dao.BlogMapper.insertBlog",blog);
            // 检测是否将插入数据的主键返回
            System.out.println(blog.getId());
            sqlSession.commit();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (sqlSession != null) {
                sqlSession.close();
            }
        }
    }

运行结果

img_512bdf28ff7f5785f98f8dc571fe26aa.png
运行结果
img_3e3bcfe7004a2369b25390d8a8b437a4.png
运行程序之后数据库内容

注意:还有一种实现方式是在insert内部添加<SelectKey>节点,这里就不再演示。

SQL映射文件参数分析

在Mapper.xml文件中,SQL语句里我们可以传入对象,或传入其它参数。
当我们以如下方式传递参数时:

  // 这是在UserMapp.java文件
  int insertByParam(int id,String name, String email);
 //UserMapper.xml文件中
    <insert id="insertByParam">
        INSERT INTO User (id,name,email) VALUE (#{id},#{name},#{email})
    </insert>

测试程序如下:

@Test
    public void test2(){
        InputStream inputStream = null;
        SqlSession sqlSession = null;
        try {
            inputStream = Resources.getResourceAsStream("mybatis-config.xml");
            SqlSessionFactory mSqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            sqlSession = mSqlSessionFactory.openSession();

            UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
            userMapper.insertByParam(2,"Gao","gao@gmail.com");

            sqlSession.commit();
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (sqlSession != null) {
                sqlSession.close();
            }
        }
    }

这个时候程序运行会出现如下错误,提示我们找不到参数。

### Cause: org.apache.ibatis.binding.BindingException: Parameter 'id' not found. Available parameters are [arg2, arg1, arg0, param3, param1, param2]
解决方法:四种任选其一
  • 修改UserMapp.java文件添加@Param注解,即可
int insertByParam(@Param("id") int id,@Param("name") String name, @Param("email") String email);
  • 修改UserMapper.xml文件,修改为param*类型如下
    <insert id="insertByParam"  >
        INSERT INTO User (id,name,email) VALUE (#{param1},#{param2}, #{param3})
    </insert>
  • 将参数换为对象,如下
// UserMapper.java修改为如下
    int insertByPoDo(User user);

//UserMapper.java修改为下
   <insert id="insertByPoDo"
        parameterType="User"
    >
        INSERT INTO User (name,email) VALUE (#{name},#{email})
    </insert>

//Test文件修改为如下
    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
    User user = new User("leishen","Rxlen@126.com");
    userMapper.insertByPoDo(user);
  • 将参数转为Map对象。
     int insertByMap(Map<String,Object> map);

//xml
      <insert id="insertByMap">
          INSERT INTO User (name,email) VALUE (#{name},#{email})
      </insert>

//Test
            UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

            HashMap<String,Object> map = new HashMap<String, Object>();
            map.put("name","test");
            map.put("email","test@qq.com");
            userMapper.insertByMap(map);

            sqlSession.commit();

一般来说,模型与业务相关传入POJO对象,与业务无关就传入Map对象。
注意:关于参数封装原理部分请查看MapperMethod.java,ParamNameResolve.java

SQL语句中$与#的区别

默认情况下,使用#{}格式的语法会导致 MyBatis 创建预处理语句属性并安全地设置值(比如?)。这样做更安全,更迅速,通常也是首选做法,不过有时你只是想直接在 SQL 语句中插入一个不改变的字符串。比如,像 ORDER BY,你可以这样来使用:

ORDER BY ${columnName}

这里 MyBatis 不会修改或转义字符串。
注意:** 以这种方式接受从用户输出的内容并提供给语句中不变的字符串是不安全的,会导致潜在的 SQL 注入攻击,因此要么不允许用户输入这些字段,要么自行转义并检验。**

$是字符串替换,#会进行预编译

获取列表数据

// UserMapper接口
    List<User> getUserByEmail(@Param("email") String email);

// UserMaper.xml
    <select id="getUserByEmail" resultType="me.aihe.dao.User">
        SELECT * FROM User WHERE email LIKE #{email}
    </select>

//测试文件
   UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

   List<User> result = userMapper.getUserByEmail("aihe%");
   System.out.println(result);

最终输出内容

img_6a822255c22796e5954839f88c603804.png
获取列表数据结果

获取Map数据

//UserMapeer接口文件
    Map<String,Object> getUserMapById(@Param("id") Integer id);

//UserMapper.xml文件
    <select id="getUserMapById" resultType="java.util.Map">
        SELECT * FROM User WHERE id = #{id}
    </select>

//测试程序
    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

    Map result = userMapper.getUserMapById(2);
    System.out.println(result);

测试输出结果

img_c3b3f9c4a012b636b6e7b0560275fbce.png
获取Map数据结果

获取Map映射的多组数据

这个和获取列表很类似了,只不过把数组都封装到一个Map中去了

// UserMapper接口文件
    @MapKey("id")
    Map<Integer,User> getUserMapLikeemail(@Param("email") String email);

// UserMapper.xml文件

    <select id="getUserMapById" resultType="java.util.Map">
        SELECT * FROM User WHERE id = #{id}
    </select>

// 测试文件
    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);

    Map result = userMapper.getUserMapLikeemail("%aihe%");
    System.out.println(result);

程序输出

img_9e918f1a2cb313ccc8ab242c1aa05195.png
获取Map映射的多组数据

**注意: 注解@MapKey指定的是以数据库表中的那一列作为Map结果的key。

使用ResultMap来映射结果数据

// UserMapper接口
    User getUserMapByIdThroughResultMap(@Param("id") Integer id);

// UserMapper.xml文件
    //Id标识的是查询结果中的主键是那一列,对应的User属性是什么
    <resultMap id="MyResultMap" type="User">
        <id column="id" property="id" />    
        <result property="email" column="email" />
        <result property="name" column="name" />
    </resultMap>

    <select id="getUserMapByIdThroughResultMap" resultMap="MyResultMap">
        SELECT * FROM User WHERE id = #{id}
    </select>

//测试文件
   UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
   User user = userMapper.getUserMapByIdThroughResultMap(2);
   System.out.println(user);

输出结果

img_4192b1fdd82e9c51d123ab5b96c68e1f.png
ResultMap映射结果数据

总结

本文主要讲解了几个Mybatis日常使用中经常用到的几个知识点,获取主键,参数映射,及$与#符号的区别,最后演示一些各种获取数据库中结果的方式。

参考

Mybatis 官方文档
Mybatis 视频教程

相关文章
|
11月前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
1741 5
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
11月前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
2710 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
|
11月前
|
SQL 存储 数据库
深入理解@TableField注解的使用-MybatisPlus教程
`@TableField`注解在MyBatis-Plus中是一个非常灵活和强大的工具,能够帮助开发者精细控制实体类与数据库表字段之间的映射关系。通过合理使用 `@TableField`注解,可以实现字段名称映射、自动填充、条件查询以及自定义类型处理等高级功能。这些功能在实际开发中,可以显著提高代码的可读性和维护性。如果需要进一步优化和管理你的MyBatis-Plus应用程
845 3
|
XML 缓存 Java
一文讲明Mybatis 的使用 超详细 【爆肝两万字教程】
文章提供了一份详尽的Mybatis使用教程,涵盖了Mybatis的简介、环境搭建、基本操作、配置解析、日志使用、分页、注解开发、多对一和一对多关系处理、动态SQL以及缓存机制等方面的内容,并提供了相应的代码示例和测试用例。
一文讲明Mybatis 的使用 超详细 【爆肝两万字教程】
|
SQL Java 数据库连接
Spring Boot联手MyBatis,打造开发利器:从入门到精通,实战教程带你飞越编程高峰!
【8月更文挑战第29天】Spring Boot与MyBatis分别是Java快速开发和持久层框架的优秀代表。本文通过整合Spring Boot与MyBatis,展示了如何在项目中添加相关依赖、配置数据源及MyBatis,并通过实战示例介绍了实体类、Mapper接口及Controller的创建过程。通过本文,你将学会如何利用这两款工具提高开发效率,实现数据的增删查改等复杂操作,为实际项目开发提供有力支持。
1125 0
|
SQL XML Java
Mybatis进阶——动态SQL(1)
Mybatis进阶——动态SQL(1)
120 3
MyBatisPlus如何根据id批量查询?Required request parameter ‘id‘ for method 解决方法是看青戈大佬MybatisPlus的教程
MyBatisPlus如何根据id批量查询?Required request parameter ‘id‘ for method 解决方法是看青戈大佬MybatisPlus的教程
|
XML Java 数据库连接
Mybatis-Plus学习小项目及详细教程
Mybatis-Plus学习小项目及详细教程