MyBatis常规CURD详解及拓展~
目录
- 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:参数类型
步骤:
编写Mapper接口,在UserMapper中添加插入一个用户的方法
返回值为受影响的行数,所以为int类型
//insert一个用户
int addUser(User user);
- 编写Mapper.xml对应配置文件,在UserMapper.xml中添加insert语句
<insert id="addUser" parameterType="pojo.User">insert into mybatis.user(id,name,pwd) values (#{id},#{name},#{pwd});
</insert>
- 在测试类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:参数类型
步骤:
编写Mapper接口,在UserMapper中添加删除一个用户的方法
返回值为受影响的行数,所以为int类型
//删除一个用户
int deleteUser(int id);
- 编写Mapper.xml对应配置文件,在UserMapper.xml中添加delete语句
<delete id="deleteUser" parameterType="int">delete from mybatis.user where id=#{id};
</delete>
- 在测试类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:参数类型
步骤:
编写Mapper接口,在UserMapper中添加删除一个修改用户信息的方法
返回值为受影响的行数,所以为int类型
//修改用户
int updateUser(User user);
- 编写Mapper.xml对应配置文件,在UserMapper.xml中添加update语句
<update id="updateUser" parameterType="pojo.User">update mybatis.user set name=#{name},pwd=#{pwd} where id=#{id} ;
</update>
- 在测试类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语句执行的返回值
步骤:
编写Mapper接口,在UserMapper中添加删除一个根据ID查询用户的方法
返回值为
//根据ID查询用户
User getUserByID(int id);
- 编写Mapper.xml对应配置文件,在UserMapper.xml中添加select语句
<select id="getUserByID" parameterType="int" resultType="pojo.User">select * from mybatis.user where id= #{id};
</select>
- 在测试类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详解及拓展~相关推荐
- 封装成jar包_通用源码阅读指导mybatis源码详解:io包
io包 io包即输入/输出包,负责完成 MyBatis中与输入/输出相关的操作. 说到输入/输出,首先想到的就是对磁盘文件的读写.在 MyBatis的工作中,与磁盘文件的交互主要是对 xml配置文件的 ...
- MyBatis核心配置文件详解
MyBatis核心配置文件详解 1.核心配置文件中的标签必须按照固定的顺序 2.properties标签 3.settings标签 4.typeAliases标签 5.environments标签 6 ...
- 如何配置Mybatis?(详解)
如何配置Mybatis?(详解) 官网文档: https://mybatis.org/mybatis-3/zh/getting-started.html pom.xml <?xml versio ...
- Mybatis案例超详解
Mybatis案例超详解 前言: 本来是想像之前一样继续跟新Mybatis,但由于种种原因,迟迟没有更新,快开学了,学了一个暑假,博客也更新了不少,我觉得我得缓缓,先整合一些案例练练,等我再成熟点理解 ...
- Mybatis的特性详解——动态SQL
Mybatis的特性详解--动态SQL 前言 一.动态sql的元素 1.MyBatis if标签:条件判断 2.MyBatis choose.when和otherwise标签 3.MyBatis wh ...
- mybatis的原理详解
mybatis的原理详解 原理图 执行的原理图如下图所示: 配置文件分析 config.xml: <?xml version="1.0" encoding="UTF ...
- 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 ...
- MyBatis中resultMap详解
MyBatis 中 resultMap 详解 resultMap 是 Mybatis 最强大的元素之一,它可以将查询到的复杂数据(比如查询到几个表中数据)映射到一个结果集当中.如在实际应用中,有一个表 ...
- Mybatis的入门详解
mybatis简介 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为M ...
最新文章
- jQuery中的插件机制
- nova-scheduler详解 openstack-ice版
- python装饰器作用-Python装饰器的通俗理解
- ASP.NET验证控件详细使用解释
- 一些SqlServer常见和入门操作
- IT技术人员必须思考的几个问题
- Linux C++线程池实例
- Python学习---Django的基础操作180116
- 6月26号.NET面试题(程序题部分)只要做懂这3道题肯定能脱离菜鸟称号!
- Forrester报告拆解:强劲冲击第一梯队后,京东智联云站稳云市场新格局
- 了解REST:动词,错误代码和身份验证
- XeLaTeX-中文排版解决方案
- 【目标检测】SSD算法
- realsense ros 三维点云地面检测与障碍物聚类
- 对于无线网络经常掉线的问题
- 网络基础虚拟化VRRP/MSTP冗余技术
- 2019级软件工程应用与实践-人工智能快递柜(综述)
- 《Java并发编程的艺术》读书笔记三
- 撰写全英文EI会议论文值得注意的要点!
- CVPR 2022 | 商汤/上交/港中文提出U2PL:使用不可靠伪标签的半监督语义分割
热门文章
- 2022-2028年成都餐饮业投资分析及前景预测报告
- 2022-2028年中国农用塑料薄膜行业市场研究及前瞻分析报告
- Go 知识点(12) — 类型转换以三方库 cast
- 2022-2028年中国XPS挤塑板行业市场全景评估及产业前景规划报告
- debian10 Unable to correct problems, you have held broken packages.
- IntelliJ IDEA中用快捷键自动创建测试类
- Redis 使用技巧
- Exception in thread main java.lang.Error: 无法解析的编译问题: 	方法 main 不能声明为 static;只能在静态类型或顶级类型中才能声明静态方法
- MLIR与Code Generation
- 如何为应用选择最佳的FPGA(下)