目录

  • 1. insert(增)
  • 2. delete(删)
  • 3. update(改)
  • 4. select(查)
  • SQL优化:Map传参
    • 示例:插入一个用户
    • map传参优点
    • 各种传参对比
  • 补充:模糊查询

本文的实验环境基于上篇博客 第一个MyBatis程序

Mapper.xml配置文件

  • 配置文件中namespace中的名称为对应Mapper接口的完整包名,必须一致!
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="mapper.UserMapper"><!--SQL语句-->
</mapper>

注意:增删改需要提交事务

1. insert(增)

  • insert – 映射插入语句
  • insert语句两个常见属性,更多属性查看中文文档
    • id:对应namespace中的方法名
    • parameterType:参数类型

步骤

  1. 编写Mapper接口,在UserMapper中添加插入一个用户的方法

    返回值为受影响的行数,所以为int类型

//insert一个用户
int addUser(User user);
  1. 编写Mapper.xml对应配置文件,在UserMapper.xml中添加insert语句
<insert id="addUser" parameterType="pojo.User">insert into mybatis.user(id,name,pwd) values (#{id},#{name},#{pwd});
</insert>
  1. 测试类UserMapperTest中添加对应的测试方法进行测试
//需要提交事务
@Test
public void addUser() {//获取sqlSession对象SqlSession sqlSession = MyBatisUtils.getSqlSession();//执行SQLUserMapper mapper = sqlSession.getMapper(UserMapper.class);mapper.addUser(new User(4, "zyx", "111111"));//提交事务sqlSession.commit();//关闭sqlSessionsqlSession.close();
}

2. delete(删)

  • delete – 映射删除语句
  • delete语句两个常见属性,更多属性查看中文文档
    • id:对应namespace中的方法名
    • parameterType:参数类型

步骤

  1. 编写Mapper接口,在UserMapper中添加删除一个用户的方法

    返回值为受影响的行数,所以为int类型

//删除一个用户
int deleteUser(int id);
  1. 编写Mapper.xml对应配置文件,在UserMapper.xml中添加delete语句
<delete id="deleteUser" parameterType="int">delete from mybatis.user where id=#{id};
</delete>
  1. 测试类UserMapperTest中添加对应的测试方法进行测试
//需要提交事务
@Test
public void addUser() {//获取sqlSession对象SqlSession sqlSession = MyBatisUtils.getSqlSession();//执行SQLUserMapper mapper = sqlSession.getMapper(UserMapper.class);mapper.deleteUser(4);//提交事务sqlSession.commit();//关闭sqlSessionsqlSession.close();
}

3. update(改)

  • update – 映射更新语句
  • update语句两个常见属性,更多属性查看中文文档
    • id:对应namespace中的方法名
    • parameterType:参数类型

步骤

  1. 编写Mapper接口,在UserMapper中添加删除一个修改用户信息的方法

    返回值为受影响的行数,所以为int类型

//修改用户
int updateUser(User user);
  1. 编写Mapper.xml对应配置文件,在UserMapper.xml中添加update语句
<update id="updateUser" parameterType="pojo.User">update mybatis.user set name=#{name},pwd=#{pwd} where id=#{id} ;
</update>
  1. 测试类UserMapperTest中添加对应的测试方法进行测试
//需要提交事务
@Test
public void addUser() {//获取sqlSession对象SqlSession sqlSession = MyBatisUtils.getSqlSession();//执行SQLUserMapper mapper = sqlSession.getMapper(UserMapper.class);mapper.updateUser(new User(4, "zyx", "222222"));//提交事务sqlSession.commit();//关闭sqlSessionsqlSession.close();
}

4. select(查)

  • select – 映射查询语句
  • select语句有很多属性可以详细配置每一条SQL语句,这里是三个常见属性,更多属性查看中文文档
    • id:对应namespace中的方法名
    • parameterType:参数类型
    • resultType:SQL语句执行的返回值

步骤

  1. 编写Mapper接口,在UserMapper中添加删除一个根据ID查询用户的方法

    返回值

//根据ID查询用户
User getUserByID(int id);
  1. 编写Mapper.xml对应配置文件,在UserMapper.xml中添加select语句
<select id="getUserByID" parameterType="int" resultType="pojo.User">select * from mybatis.user where id= #{id};
</select>
  1. 测试类UserMapperTest中添加对应的测试方法进行测试
@Test
public void getUserByID() {//获取sqlSession对象SqlSession sqlSession = MyBatisUtils.getSqlSession();//执行SQLUserMapper mapper = sqlSession.getMapper(UserMapper.class);User user = mapper.getUserByID(1);System.out.println(user);//关闭sqlSessionsqlSession.close();
}

SQL优化:Map传参

假设,我们的实体类或者数据库中的表,字段或者参数过多,应该考虑使用Map

示例:插入一个用户

1、在接口方法中,参数直接传递Map;

//增加一个用户
int addUser2(Map<String, Object> map);

2、编写sql语句的时候,需要传递参数类型,参数类型为map

<insert id="addUser2" parameterType="Map">insert into mybatis.user(id,name,pwd) values (#{userid},#{username},#{userpwd});
</insert>

3、编写测试方法:在使用方法的时候,Map的 key 为 sql中取的值即可,没有顺序要求!

@Test
public void addUser2() {//获取sqlSession对象SqlSession sqlSession = MyBatisUtils.getSqlSession();//执行SQLUserMapper mapper = sqlSession.getMapper(UserMapper.class);Map<String, Object> map = new HashMap<String, Object>();map.put("userid",5);map.put("username","hello");map.put("userpwd",333333);mapper.addUser2(map);//提交事务sqlSession.commit();//关闭sqlSessionsqlSession.close();
}

map传参优点

对比上述方法

  • 在编写sql语句的时候,参数名(map的key)可以任意,只要一一对应即可,不同于通过User对象传参,参数名必须于字段名相同
id-->userid
name-->username
pwd-->userpwd

假设只需要修改一个密码,通过一整个对象传参必须new出一整个对象,其他属性都必须实例化出来,而使用map传参的时候,只需要传一个密码即可;

  • 所以,当我们的实体类或者数据库中的表,字段或者参数过多时,建议使用map传参,可以针对单一字段,而不是以整体为单位

各种传参对比

  • Map传递参数,直接在sql中取出key即可 parameterType="Map"
  • 对象传递参数,直接在sql中取对象的属性即可 parameterType="Object"
  • 只有一个基本类型参数的情况下,直接在sql中取到 parameterType="int"(一个参数可以省略parameterType)

补充:模糊查询

模糊查询的实现有两种方法,我们以一个示例进行讲解~

首先在接口中添加对应方法,这里进行name的模糊查询

//模糊查询
List<User> getUserLike(String value);

第1种:在Java代码中添加sql通配符。

<select id="getUserLike" resultType="pojo.User">select * from mybatis.user where name like #{value}
</select>
@Testpublic void getUserLike() {//获取sqlSession对象SqlSession sqlSession = MyBatisUtils.getSqlSession();//执行SQLUserMapper mapper = sqlSession.getMapper(UserMapper.class);List<User> userList = mapper.getUserLike("%z%");//添加sql通配符for (User user : userList) {System.out.println(user);}//关闭sqlSessionsqlSession.close();}

第2种:在sql语句中拼接通配符,可能会引起sql注入

<select id="getUserLike" resultType="pojo.User">select * from mybatis.user where name like "%"#{value}"%"
</select>
@Testpublic void getUserLike() {//获取sqlSession对象SqlSession sqlSession = MyBatisUtils.getSqlSession();//执行SQLUserMapper mapper = sqlSession.getMapper(UserMapper.class);List<User> userList = mapper.getUserLike("z");for (User user : userList) {System.out.println(user);}//关闭sqlSessionsqlSession.close();}

总结

  • 对于模糊查询的两种方式,建议使用第一种方式,第二种方式存在sql注入的问题

  • 为了防止sql注入,所以参数尽量写死,让用户传入的是一个正确的参数


MyBatis常规CURD详解及拓展~相关推荐

  1. 封装成jar包_通用源码阅读指导mybatis源码详解:io包

    io包 io包即输入/输出包,负责完成 MyBatis中与输入/输出相关的操作. 说到输入/输出,首先想到的就是对磁盘文件的读写.在 MyBatis的工作中,与磁盘文件的交互主要是对 xml配置文件的 ...

  2. MyBatis核心配置文件详解

    MyBatis核心配置文件详解 1.核心配置文件中的标签必须按照固定的顺序 2.properties标签 3.settings标签 4.typeAliases标签 5.environments标签 6 ...

  3. 如何配置Mybatis?(详解)

    如何配置Mybatis?(详解) 官网文档: https://mybatis.org/mybatis-3/zh/getting-started.html pom.xml <?xml versio ...

  4. Mybatis案例超详解

    Mybatis案例超详解 前言: 本来是想像之前一样继续跟新Mybatis,但由于种种原因,迟迟没有更新,快开学了,学了一个暑假,博客也更新了不少,我觉得我得缓缓,先整合一些案例练练,等我再成熟点理解 ...

  5. Mybatis的特性详解——动态SQL

    Mybatis的特性详解--动态SQL 前言 一.动态sql的元素 1.MyBatis if标签:条件判断 2.MyBatis choose.when和otherwise标签 3.MyBatis wh ...

  6. mybatis的原理详解

    mybatis的原理详解 原理图 执行的原理图如下图所示: 配置文件分析 config.xml: <?xml version="1.0" encoding="UTF ...

  7. MyBatis SQL语句详解

    MyBatis SQL语句详解 1 CRUD标签 1.1 select 1.2 insert 1.3 update 1.4 delete 1.5 #{ }和${ }的区别 2 动态SQL 2.1 if ...

  8. MyBatis中resultMap详解

    MyBatis 中 resultMap 详解 resultMap 是 Mybatis 最强大的元素之一,它可以将查询到的复杂数据(比如查询到几个表中数据)映射到一个结果集当中.如在实际应用中,有一个表 ...

  9. Mybatis的入门详解

    mybatis简介 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为M ...

最新文章

  1. jQuery中的插件机制
  2. nova-scheduler详解 openstack-ice版
  3. python装饰器作用-Python装饰器的通俗理解
  4. ASP.NET验证控件详细使用解释
  5. 一些SqlServer常见和入门操作
  6. IT技术人员必须思考的几个问题
  7. Linux C++线程池实例
  8. Python学习---Django的基础操作180116
  9. 6月26号.NET面试题(程序题部分)只要做懂这3道题肯定能脱离菜鸟称号!
  10. Forrester报告拆解:强劲冲击第一梯队后,京东智联云站稳云市场新格局
  11. 了解REST:动词,错误代码和身份验证
  12. XeLaTeX-中文排版解决方案
  13. 【目标检测】SSD算法
  14. realsense ros 三维点云地面检测与障碍物聚类
  15. 对于无线网络经常掉线的问题
  16. 网络基础虚拟化VRRP/MSTP冗余技术
  17. 2019级软件工程应用与实践-人工智能快递柜(综述)
  18. 《Java并发编程的艺术》读书笔记三
  19. 撰写全英文EI会议论文值得注意的要点!
  20. CVPR 2022 | 商汤/上交/港中文提出U2PL:使用不可靠伪标签的半监督语义分割

热门文章

  1. 2022-2028年成都餐饮业投资分析及前景预测报告
  2. 2022-2028年中国农用塑料薄膜行业市场研究及前瞻分析报告
  3. Go 知识点(12) — 类型转换以三方库 cast
  4. 2022-2028年中国XPS挤塑板行业市场全景评估及产业前景规划报告
  5. debian10 Unable to correct problems, you have held broken packages.
  6. IntelliJ IDEA中用快捷键自动创建测试类
  7. Redis 使用技巧
  8. Exception in thread main java.lang.Error: 无法解析的编译问题: 方法 main 不能声明为 static;只能在静态类型或顶级类型中才能声明静态方法
  9. MLIR与Code Generation
  10. 如何为应用选择最佳的FPGA(下)