MyBatis的Mapper 代理的增删改查操作(三)中

简介: MyBatis的Mapper 代理的增删改查操作(三)

三. 测试


三.一 根据id 查询单个对象


@Test
  public void getByIdTest(){
    SqlSession sqlSession=SqlSessionFactoryUtils.getSession();
    // 获取相应的 实体Mapper,  是接口的形式
    UserMapper userMapper=sqlSession.getMapper(UserMapper.class);
    // 调用userMapper 接口中的方法  getById 
    User user=userMapper.getById(1);
    System.out.println(user);
  }


20190618193238325.png


三.二 查询全部的对象


@Test
  public void findAllTest(){
    SqlSession sqlSession=SqlSessionFactoryUtils.getSession();
    UserMapper userMapper=sqlSession.getMapper(UserMapper.class);
    List<User> allList=userMapper.findAll();
    allList.forEach(n ->System.out.println(n));
  }


测试运行效果:


20190618193711586.png


只需要接口 即可,不需要相应的实现类。


四. Mapper 方式的匹配点


在利用Mapper 方式进行处理的时候,需要遵守以下的几个原则:


1.接口名称与类配置文件的名称保持一致。 一个是UserMapper.java, 一个是UserMapper.xml , 最好的命名方式为 类实体+Mapper 的形式。 (非必须)


2.xml 文件的命名空间为 接口的全限定名称, 这样可以方便的找到用的是哪一个接口。


<mapper namespace="com.yjl.mapper.UserMapper">


3.接口中的方法名称要与 xml配置文件中的id 保持一致。

如方法名称是 getById, 那么select 语句中的id 就是getById, 方法名称是insertUser, 那么insert 语句中的id 就是insertUser 。 可用于方法重载的情况。


4.参数类型一致. 接口中的方法的参数类型要与 statement 中的parameterType 的类型保持一致。


5.返回结果一致。 接口中的方法的返回值,要与statement 中的resultType 的类型保持一致,但并非一模一样。 接口的返回类型为List, resultType 的类型只是对象类型即可。


保持一致是为了自动生成代码。


User user = sqlSession.selectOne("test.findUserById", id);
sqlSession.insert("test.insertUser", user);


五. 插入操作 insert


五.一 普通插入


UserMapper.java 中接口:


public int insertUser(User user);


UserMapper.xml 中接口:


<!-- 插入语句,用别名的方法 user 来替换 com.yjl.pojo.User 类 -->
  <insert id="insertUser" parameterType="user"> 
    insert into user(name,age,sex,description) 
    values(#{name},#{age},#{sex} ,#{description}) 
  </insert>


测试方法,有自动提交,回滚的 异常处理的。


@Test
  public void insertTest(){
    SqlSession sqlSession=SqlSessionFactoryUtils.getSession();
    UserMapper userMapper=sqlSession.getMapper(UserMapper.class);
    User user=new User();
    user.setName("老蝴蝶");
    user.setAge(25);
    user.setSex("男");
    user.setDescription("这是一个老蝴蝶");
    try{
      userMapper.insertUser(user);  //调用插入的方法,进行插入。
      //需要手动提交事务
      sqlSession.commit();
    }catch(Exception e){
      sqlSession.rollback();
    }finally{
      sqlSession.close();
    }
    System.out.println("输出信息:"+user);
  }


测试运行之后:


20190618194954275.png


数据库插入数据: (为3的那一条是 sqlSession 没有手动提交的脏数据)


20190618195106952.png


五.二 有id 值的处理


五.一 处理时,发现查询时,并没有查询出id 的值。 需要查询出id 的值信息。


<!-- 插入记录 ,获取id编号-->
  <insert id="insertUser" parameterType="user" keyProperty="id" useGeneratedKeys="true">
    insert into user(name,age,sex,description) values(#{name},#{age},#{sex}
    ,#{description})
  </insert>


测试方法不变, 日志输出为:


20190618195253241.png


有相应的id 信息。


五.三 数据库查询id


<!-- 数据库查询,获取id编号-->
  <insert id="insertUser" parameterType="com.yjl.pojo.User">
    <selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
      select last_insert_id()
    </selectKey>
    insert into user(name,age,sex,description) values(#{name},#{age},#{sex}
    ,#{description})
  </insert>


输出日志为:


20190618195427873.png


五.四 uuid 插入


将id 的类型 改成String 类型,


20190618195648751.png


数据库中id 列的类型也改成varchar 类型


20190618195724126.png


xml sql语句为:


<!-- uuid插入,获取id编号-->
  <insert id="insertUser" parameterType="user">
    <selectKey keyProperty="id" order="BEFORE" resultType="java.lang.String">
      select uuid()
    </selectKey>
    <!-- 这个时候,sql 语句就要写id 了。 -->
    insert into user(id,name,age,sex,description) values(#{id},#{name},#{age},#{sex}
    ,#{description})
  </insert>


测试方法:


  @Test
  public void insertTest(){
    SqlSession sqlSession=SqlSessionFactoryUtils.getSession();
    UserMapper userMapper=sqlSession.getMapper(UserMapper.class);
    User user=new User();
    user.setName("老蝴蝶uuid");
    user.setAge(25);
    user.setSex("男");
    user.setDescription("这是一个老蝴蝶uuid 测试");
    try{
      userMapper.insertUser(user);  //调用插入的方法,进行插入。
      //需要手动提交事务
      sqlSession.commit();
    }catch(Exception e){
      sqlSession.rollback();
    }finally{
      sqlSession.close();
    }
    System.out.println("输出信息:"+user);
  }


输出日志为:


20190618200426441.png


五.五 序列形式的插入


没有oracle 客户端,不进行验证了。


<!-- oracle 序列插入,获取id编号-->
  <insert id="insertUser" parameterType="com.yjl.pojo.User">
    <selectKey keyProperty="id" order="BEFORE" resultType="java.lang.Integer">
      select 序列名.nextval() 
    </selectKey>
    <!-- 这个时候,sql 语句就要写id 了。 -->
    insert into user(id,name,age,sex,description) values(#{id},#{name},#{age},#{sex}
    ,#{description})
  </insert>


六. 修改操作 update


修改的接口 :


public int updateUser(User user);


修改对应的xml sql语句:


<update id="updateUser" parameterType="user">
    update user set name=#{name},sex=#{sex},age=#{age},description=#{description}
    where id=#{id}
  </update>



相关文章
|
30天前
|
SQL Java 数据库连接
mybatis使用四:dao接口参数与mapper 接口中SQL的对应和对应方式的总结,MyBatis的parameterType传入参数类型
这篇文章是关于MyBatis中DAO接口参数与Mapper接口中SQL的对应关系,以及如何使用parameterType传入参数类型的详细总结。
30 10
|
2月前
|
SQL XML Java
mybatis复习02,简单的增删改查,@Param注解多个参数,resultType与resultMap的区别,#{}预编译参数
文章介绍了MyBatis的简单增删改查操作,包括创建数据表、实体类、配置文件、Mapper接口及其XML文件,并解释了`#{}`预编译参数和`@Param`注解的使用。同时,还涵盖了resultType与resultMap的区别,并提供了完整的代码实例和测试用例。
mybatis复习02,简单的增删改查,@Param注解多个参数,resultType与resultMap的区别,#{}预编译参数
|
3月前
|
SQL Java 数据库连接
Mybatis系列之 Error parsing SQL Mapper Configuration. Could not find resource com/zyz/mybatis/mapper/
文章讲述了在使用Mybatis时遇到的资源文件找不到的问题,并提供了通过修改Maven配置来解决资源文件编译到target目录下的方法。
Mybatis系列之 Error parsing SQL Mapper Configuration. Could not find resource com/zyz/mybatis/mapper/
|
2月前
|
SQL XML Java
mybatis :sqlmapconfig.xml配置 ++++Mapper XML 文件(sql/insert/delete/update/select)(增删改查)用法
当然,这些仅是MyBatis功能的初步介绍。MyBatis还提供了高级特性,如动态SQL、类型处理器、插件等,可以进一步提供对数据库交互的强大支持和灵活性。希望上述内容对您理解MyBatis的基本操作有所帮助。在实际使用中,您可能还需要根据具体的业务要求调整和优化SQL语句和配置。
44 1
|
3月前
|
druid Java 数据库连接
SpringBoot项目整合MybatisPlus持久层框架+Druid数据库连接池,以及实现增删改查功能
SpringBoot项目整合MybatisPlus和Druid数据库连接池,实现基本的增删改查功能。
315 0
|
3月前
|
XML Java 数据库连接
Mybatis 模块拆份带来的 Mapper 扫描问题
Mybatis 模块拆份带来的 Mapper 扫描问题
43 0
|
30天前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
91 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
30天前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
52 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
1月前
|
前端开发 Java Apache
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
本文详细讲解了如何整合Apache Shiro与Spring Boot项目,包括数据库准备、项目配置、实体类、Mapper、Service、Controller的创建和配置,以及Shiro的配置和使用。
267 1
Springboot整合shiro,带你学会shiro,入门级别教程,由浅入深,完整代码案例,各位项目想加这个模块的人也可以看这个,又或者不会mybatis-plus的也可以看这个
|
30天前
|
SQL Java 数据库连接
mybatis使用二:springboot 整合 mybatis,创建开发环境
这篇文章介绍了如何在SpringBoot项目中整合Mybatis和MybatisGenerator,包括添加依赖、配置数据源、修改启动主类、编写Java代码,以及使用Postman进行接口测试。
15 0
mybatis使用二:springboot 整合 mybatis,创建开发环境