本文是按照狂神说的教学视频学习的笔记,强力推荐,教学深入浅出1便就懂!b站搜索狂神说即可

https://space.bilibili.com/95256449?spm_id_from=333.788.b_765f7570696e666f.2

MyBatis中的基本CRUD

接上一篇博客:https://www.cnblogs.com/renzhongpei/p/12559788.html

修改图中的类

Mapper接口

package com.rzp.dao;

import com.rzp.pojo.User;

import java.util.List;

public interface UserMapper {
   List<User> getUserList();

   //根据ID查询用户
   User getUserById (int id);

   //insert 一个用户
   void addUser(User user);

   //update 一个用户
   void updateUser(User user);

   //delete 一个用户
   void deleteUser(int id);
}

Mapper.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.rzp.dao.UserMapper">
   <select id="getUserList" resultType="com.rzp.pojo.User">
   select * from mybatis.user
   </select>
   
   <!--id是对应的方法名字,parameterType是输入参数的类型-->
   <select id="getUserById" resultType="com.rzp.pojo.User" parameterType="int">
   <!-- #{id}是实体类的属性,只要属性名字一样就能完成-->
   select * from mybatis.user t where t.id = #{id}
   </select>

   <insert id="addUser" parameterType="com.rzp.pojo.User" >
       insert into mybatis.user (id,name,pwd) value (#{id},#{name},#{pwd});
   </insert>

   <update id="updateUser" parameterType="com.rzp.pojo.User">
       update mybatis.user set name = #{name}, pwd = #{pwd} where  id = #{id};
   </update>

   <delete id="deleteUser"  parameterType="int">
       delete from mybatis.user where id = #{id};
   </delete>


</mapper>

测试程序UserDaoTest

按方法测试即可

    
   //按ID查询
   @Test
   public void getUserById(){
       SqlSession sqlSession = MybatisUtils.getSqlSession();
       try {
           UserMapper mapper = sqlSession.getMapper(UserMapper.class);
           User user = mapper.getUserById(1);
           System.out.println(user);
      }catch (Exception e){
           e.printStackTrace();
      }finally {
           sqlSession.close();
      }
  }

   //增删改需要提交事务
   //增加
   @Test
   public void addUser(){
       SqlSession sqlSession = MybatisUtils.getSqlSession();
       try {
           UserMapper mapper = sqlSession.getMapper(UserMapper.class);
           User user = new User(6,"rzp3","312");
           mapper.addUser(user);
           int x = 1/0;

           //提交事务
           sqlSession.commit();
      }catch (Exception e){
           e.printStackTrace();
           //错误则回滚,其实不需要,程序已经封装好会回滚
           sqlSession.rollback();
      }finally {
           sqlSession.close();
      }
  }
   
   //更新
   @Test
   public void updateUser(){
       SqlSession sqlSession = MybatisUtils.getSqlSession();
       try {
           UserMapper mapper = sqlSession.getMapper(UserMapper.class);
           User user = new User(3,"cys","31112");
           mapper.updateUser(user);

           //提交事务
           sqlSession.commit();
      }catch (Exception e){
           e.printStackTrace();
           //错误则回滚,其实不需要,程序已经封装好会回滚
           sqlSession.rollback();
      }finally {
           sqlSession.close();
      }

  }
   
   //删除
   @Test
   public void deleteUser(){
       SqlSession sqlSession = MybatisUtils.getSqlSession();
       try {
           UserMapper mapper = sqlSession.getMapper(UserMapper.class);
           mapper.deleteUser(5);

           //提交事务
           sqlSession.commit();
      }catch (Exception e){
           e.printStackTrace();
           //错误则回滚,其实不需要,程序已经封装好会回滚
           sqlSession.rollback();
      }finally {
           sqlSession.close();
      }

  }
 

注意:Mapper.xml配置错误(比如类名、方法名写错了)也会导致sqlSession生成的时候就报错!这个时候IDEA提示的错误会链接向sqlSession生成那一行。

使用Map来简化传参的操作

  • 数据库字段多的时候,如果只是修改其中一个两个字段,但是如果用上文的UPDATE,就要new一个实体类,操作比较麻烦。这时候可以使用map。

UserMapper接口

    //万能的map
   void addUser2(Map<String,Object> map);

UserMapper.xml

    <insert id="addUser2" parameterType="map" >
       <!--传入参数是map,用#{}取参数的时候就是按照map的key值来获取-->
       insert into mybatis.user (id,name,pwd) value (#{userid},#{username},#{password});
   </insert>

测试类

    //更新
   @Test
   public void updateUser2(){
       SqlSession sqlSession = MybatisUtils.getSqlSession();
       try{
           UserMapper mapper = sqlSession.getMapper(UserMapper.class);
           Map map = new HashMap();
           map.put("userid",5);
           map.put("username","cyy2");
           map.put("password","3212");
           mapper.addUser2(map);
           sqlSession.commit();
      }catch (Exception e){

      }finally {
           sqlSession.close();
      }
  }
  • 这里虽然使用insert作为例子,而且传了所有参数,但是显然改成update并且只传ID和要修改的参数也是可以的。

  • 同理,也可以用在select中,传多个参数查询

Mybatis中的Like查询

  • 模糊查询的两种写法

  1. 在执行的时候传递通配符

    User user = mapper.getUserById("%1%");
  1. 在xml文件中使用通配符

    select * from mybatis.user t where t.id like "%"#{id}"%"

MyBatis(二):基础CRUD的更多相关文章

  1. mybatis(二)执行CRUD操作的两种方式配置和注解

    一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...

  2. mybatis入门基础(二)----原始dao的开发和mapper代理开发

    承接上一篇 mybatis入门基础(一) 看过上一篇的朋友,肯定可以看出,里面的MybatisService中存在大量的重复代码,看起来不是很清楚,但第一次那样写,是为了解mybatis的执行步骤,先 ...

  3. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)

    本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...

  4. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    一.使用MyBatis对表执行CRUD操作--基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: 1 <?xml version="1.0&q ...

  5. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...

  6. 【转】MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    [转]MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据, ...

  7. Mybatis的学习总结二:使用Mybatis对表进行CRUD操作【参考】

    一.使用Mybatis对表进行CRUD操作------基于XML的实现 1.定义SQL的映射文件 2.在conf.xml中进行注册. 2.创建测试类 [具体过程参考:Mybatis的学习总结一] 二. ...

  8. MyBatis学习笔记(二)——使用MyBatis对表执行CRUD操作

    转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4262895.html 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用My ...

  9. 二:MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...

  10. 【Mybatis】MyBatis对表执行CRUD操作(三)

    本例在[Mybatis]MyBatis配置文件的使用(二)基础上继续学习对表执行CRUD操作 使用MyBatis对表执行CRUD操作 1.定义sql映射xml文件(EmployeeMapper.xml ...

随机推荐

  1. ggplot2(6) 标度、坐标轴和图例

    6.1 简介 标度控制着数据到图形属性的映射.标度将我们的数据转化为视觉上可以感知的东西:例如大小.颜色.位置和形状.标度也为我们提供了读图时所使用的工具:坐标轴和图例. 执行标度的过程分为三步:变换 ...

  2. 初识JVM:(二)Java的垃圾回收机制详解

    声明:本文主要参考https://www.cnblogs.com/codeobj/p/12021041.html 仅供个人学习.研究之用,请勿用于商业用途,如涉及侵权,请及时反馈,立刻删除. 一.Ja ...

  3. 人见人爱A-B 题解

    参加过上个月月赛的同学一定还记得其中的一个最简单的题目,就是{A}+{B},那个题目求的是两个集合的并集,今天我们这个A-B求的是两个集合的差,就是做集合的减法运算.(当然,大家都知道集合的定义,就是 ...

  4. nlogn的最长不下降子序列【tyvj1254挑选士兵】

    var a,d:Array[-..]of longint; i,n,m,k,l:longint; function erfen(x:longint):longint; var mid,h,t:long ...

  5. 扩展gRPC支持consul服务发现和Polly策略

    gRPC由于需要用工具生成代码实现,可开发性不是很高,在扩展这方面不是很友好 最近研究了下,进行了扩展,不需要额外的工具生成,直接使用默认Grpc.Tools生成的代理类即可 相关源码在文章底部 客户 ...

  6. 图数据库 Nebula Graph TTL 特性

    导读 身处在现在这个大数据时代,我们处理的数据量需以 TB.PB, 甚至 EB 来计算,怎么处理庞大的数据集是从事数据库领域人员的共同问题.解决这个问题的核心在于,数据库中存储的数据是否都是有效的.有 ...

  7. Selenium系列(二) - 控制浏览器操作的详细解读

    如果你还不想从头学起Selenium,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1680176.html 其次,如果你不懂前端基础知识 ...

  8. python使用argparse 、paramiko实现服务器管理器

    使用argparse,paramiko两个包去实现简易的服务器管理器,完成两种方式的连接( 密码和密钥 ),以及命令行交互,文件上传下载. 相比sys.argv的方式去判断传入的参数,如果参数较多那么 ...

  9. 报错:Error updating database. Cause: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Data too long for column 'gender' at row 1

    我遇到这个错误是解决办法:我修改了对应的数据库字段的长度:原本我设置的是char型,但是存进去的是一个string型,结果就报了这个报了这个错误 下面就是数据库修改之后的结果. 以上都是我学习过程中遇 ...

  10. dirname,basename的用法与用途

    #dirname介绍 当对文件使用dirname时,返回文件的上级目录,输出是否是绝对路径取决于输入的文件名是绝对路径 如果对目录使用,则返回上级目录 basename命令与dirname相反,读取文 ...