day03 MyBatis 核心

mapper接口和原理

之前的持久层组成部分:UserMapper.xml+IUserDAO+UserDAOimpl

使用mapper接口:UserMapper.xml+UserMaper接口

mapper接口的好处;

避免持久层里面传入参数错误:以前里面写错了不会报错,只有等到运行代码才能看到错误,第二个参数的类型是Objiect

MAPPer使用注意

1.mapper接口的命名为xxxMapper,包的路径和对应的xml文件的路径相同,编译后的路径相同

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Lj9OHtNc-1684997920735)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503150259299.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tDwffjcE-1684997920737)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503150312472.png)]

2.xml命名空间使用对应xxxmapper接口的权限定名

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TO8R9nHF-1684997920738)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503150537670.png)]

3.mapper 接口方法名和mapper.xml文件中的(select | update | delete | insert)id值一样

xml文件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-KNyNJHDm-1684997920739)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503152734887.png)]

mapper文件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OcPqv2vr-1684997920739)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503152801372.png)]

4.方法返回的类型对应xml中 resultType / resultMap 类型

5.方法的参数类型对应 SQL 元素中定义的 paramterType 类型(一般不写)。

在测试中使用mapper接口

@Test
public void get() {
    SqlSession session = MybatisUtil.getSession();
    UserMapper mapper = session.getMapper(UserMapper.class);
    System.out.println(mapper.get(1L));
    session.close();
}

注意:mapper.get是中的get是mapper接口中的方法名,里面的传的值的类型由接口进行规定

mapper接口原理

底层就是mybatis使用动态代理来创建mapper的实现类对象

底层的操作方式和以前一样

使用mapper进行多条件查询

使用多条件的时候,mybatis会将多个条件进行封装成map集合(arg0,arg1,param1,param2),

此时在xml中的select语句直接使用username=#{username} and password=#{password}就会出错

解决办法:在xxxMapper中加上@param注解,

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nLImMwC8-1684997920740)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503161637126.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QnZxj1u2-1684997920741)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503161618315.png)]

Mybatis中的#和$的区别

1.相同点

都可以获取map或者javabean中的对象信息

2.不同点

(1)**#会将所有传过来的任何类型的参数加上单引号,$**不会自动加上,只能手动在传参数那里加单引号,否则将传过来的参数作为SQL语句的一部分

(2)#可以防止sql注入问题(preparaStatement),安全,$不安全

(3)#支持将简单类型(string int)作为参数值,$不行

Mybatis中的动态sql:if和where

**使用地方:**进行多条件判断的时候

xml中的if作用

test里面的是一个boolean表达式

xml中的where作用

满足条件就将where加进去,不满足条件的就不将where进行拼接

where和if联合使用,使用CDATA进行包裹运算符,或者使用转义符

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7VzFHvDG-1684997920742)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503190758002.png)]

Mybatis中的动态sql:set

使用set可以防止修改数据的时候丢失数据,当某个属性传入的值为null的时候,会丢失数据

set和if配合进行使用,在if的外层加上set

**注意事项:**修改的时候mapper接口不能返回任何类型,否则报错,弄一个测试类进行测试

xml

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-peWEaOxT-1684997920742)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503203550475.png)]

mapper接口

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5IfLo17G-1684997920743)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503205731007.png)]

测试类

 @Test
    public  void update(){
    SqlSession session = MybatisUtil.getSession();
    EmployeeMapper mapper = session.getMapper(EmployeeMapper.class);
    Employee employee = new Employee();
    employee.setSalary(new BigDecimal(1300));
    employee.setId(1L);
    mapper.update(employee);
    session.commit();
    session.close();
}

Mybatis中的动态sql:foreach

使用地方:批量删除的时候,使用的数组或者集合进行删除就使用foreach遍历进行删除

注意事项:编写mapper接口的时候需要增加一个注解,否则一个数组xml问津不能进行识别

xml文件

<delete id="delete" >
    delete from employee
    where id in
        <!--
        collection:需要遍历的数组或者集合
        open:开始拼接的字符串
        item:遍历后元素的别名
        separatotor:遍历元素后使用的分隔符
        close:遍历结束拼接的字符串
        -->
        <foreach collection="ids" open="(" item="id" separator="," close=")">
            #{id}
        </foreach>
</delete>

mapper接口

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-t06bZELT-1684997920744)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503205546291.png)]

测试类

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BbYOftJk-1684997920745)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20230503205617420.png)]

id}


mapper接口

[外链图片转存中...(img-t06bZELT-1684997920744)]

测试类

[外链图片转存中...(img-BbYOftJk-1684997920745)]























本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/23817.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

unix环境高级编程 第一章 UNIX基础知识 Go实现代码

ls命令的Go语言实现 package mainimport ("fmt""os" )func main() {if len(os.Args) ! 2 {panic("参数数量不足")}targetPath : os.Args[1]if dirList, err : os.ReadDir(targetPath); err nil {for _, dirInfo : range dirList {fmt.Println(…

淡季不淡,满帮一季度净利创历史新高的背后原因是什么?

进入五月&#xff0c;经济复苏的成果越发体现在很多基础行业的表现中。经济的“大动脉”货运行业&#xff0c;也迎来一份新答卷。 北京时间5月22日美股盘前&#xff0c;数字货运平台满帮集团&#xff08;NYSE:YMM&#xff0c;简称&#xff1a;满帮&#xff09;&#xff0c;发布…

自动化测试用例怎么写?最全自动化测试用例设计编写指南...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 Python自动化测试&…

python---变量(3)

求字符串的长度 使用len来求字符串中有几个字符 字符串的拼接 此时是把a2字符串拼接到a1字符串的末尾&#xff0c;得到更大的字符串&#xff0c;对于原来的a1和a2是没有影响的&#xff01; 不能把字符串和数字混合相加&#xff01; 这个时候程序就会报错&#xff0c;不能…

GO语言并发编程入门:Goroutine、Channel、Context、并发安全、GMP调度模型

GO语言并发编程入门&#xff1a;Goroutine、Channel、Context、并发安全、GMP调度模型 1.GO并发介绍 并发&#xff1a;多线程程序在一个核的cpu上运行。 并行&#xff1a;多线程程序在多个核的cpu上运行。 由上可知并发不是并行&#xff0c;并行是直接利用多核实现多线程的运…

【分布式文件存储】MinIO部署及实现文件上传下载

目录 概述 MinIO集群部署 准备docker-compose.yml 测试启动 MinIO用户管理 Buckets管理 创建Buckets MinIO客户端 引入依赖 文件上传下载Demo 调用API碰到的问题 概述 MinIO | 高性能, Kubernetes 原生对象存储 MinIO是全球领先的对象存储先锋&#xff0c;目前在全世…

照相机标定

一.相机标定的原理 1.1 相机如何成像&#xff1a; 相机成像系统中&#xff0c;共包含四个坐标系&#xff1a;世界坐标系、相机坐标系、图像坐标系、像素坐标系。 1.1.1 世界坐标系&#xff1a; 世界坐标系&#xff08;world coordinate&#xff09;&#xff0c;也称为测量坐…

Cobalt Strike工具基本使用

Cobalt Strike 安装启动启动server端启动client目标机器连接 工具基使用用户驱动攻击屏幕截图进程列表键盘记录文件管理远程vnc远程代理端口扫描 生成后门被攻击者运行后门文件后查看结果 钓鱼攻击信息收集网站克隆文件下载 安装 网盘地址&#xff1a;链接&#xff1a;https:/…

PyG的Planetoid无法直接下载Cora等数据集的解决方法

问题描述&#xff1a; 在使用PyG的时候&#xff0c;通常会涉及到一些公共数据集的下载&#xff0c;由于网络问题&#xff0c;导致无法下载出现以下问题&#xff1a; 尝试了很多的方法都没有成功&#xff08;主要是个人比较菜&#xff01;&#xff09;。但是皇天不负有心人&am…

文心一言和ChatGPT最全对比

文心一言和ChatGPT都是基于深度学习技术的自然语言处理模型&#xff0c;有各自的优势和使用场景&#xff0c;无法简单地比较 ChatGPT 和文心一言哪一个功能更强大&#xff0c;它们各自具有优势和局限性&#xff0c;需要根据具体需求进行选择&#xff0c;以下一些具体对比&#…

分布式网络通信框架(十)——Mprpc框架使用示例

发布一个服务提供远程调用方法的流程 若想要发布一个服务提供一些远程调用方法&#xff0c;步骤如下&#xff1a; 先在protobuf文件中添加参数和返回值的message 类型&#xff0c;然后再添加希望提供的服务 service 类型&#xff08;如UserServiceRpc&#xff09;和 其中的方…

C++内存管理和模板

文章目录 内存管理new和delete 函数模板隐式实例化显式实例化 类模板 内存管理 有时候我们需要动态的申请内存,比如队列,栈,二叉树等数据结构,我们一开始并不知道要存储多少个数据,也就是不确定究竟要多大的内存,给小了存不下,给大了会造成内存资源的浪费,因此动态的申请内存是…

原工程运行正常,重新复制一份后再 npm install 后再运行就报错的解决办法

原工程&#xff0c;运行正常 将刚刚的工程复制一份呢&#xff0c;重新 npm install 再 npm run serve 就报错 出现这个问题十之八九都是依赖的问题。有可能是因为这个工程里面之前安装过一些东西&#xff0c;后来莫名其妙的就把 package.json 里面相关的依赖给删掉了。但由于原…

【数据结构】顺序二叉树的实现—以堆的实现为例、堆的调整、堆的创建、堆的插入和删除、堆排序

文章目录 1.堆的概念及结构2.堆的实现&#xff08;以大堆为例&#xff09;2.1堆的插入2.1.1堆的向上调整算法 2.2堆的删除2.2.1堆的向下调整算法 2.3堆的创建2.4有关建堆的时间复杂度 3.堆排序4.C语言堆实现源码 1.堆的概念及结构 堆就是顺序结构二叉树。 如果有一个关键码的集…

jetcache参考文档

jetcache简介 https://github.com/alibaba/jetcache/blob/master/docs/CN/GettingStarted.md 简介 JetCache是一个基于Java的缓存系统封装&#xff0c;提供统一的API和注解来简化缓存的使用。 JetCache提供了比SpringCache更加强大的注解&#xff0c;可以原生的支持TTL、两级…

shell变量类型含义 长方形面积计算 截取相应字段方法

1.总结变量的类型及含义&#xff1f; 2.实现课堂案例计算长方形面积&#xff1f;&#xff08;6种方式&#xff09; 3.定义变量urlhttps://blog.csdn.net/weixin_45029822/article/details/103568815&#xff08;通过多种方法实现&#xff09; 1&#xff09;截取网站访问的协议 …

文心一言 VS 讯飞星火 VS chatgpt (22)-- 算法导论4.2 2题

二、为Strassen算法编写伪代码。 文心一言&#xff1a; Strassen算法是一种用于矩阵乘法的算法&#xff0c;它的核心思想是通过不断将原始矩阵分割成较小的子矩阵来实现高效的乘法运算。以下是Strassen算法的伪代码&#xff1a; function Strassen(A, B): if A[0][0] 0 or…

Springboot整合WebSocket

目录 1.WebSocket 简介 2.WebSocket 实战 1.WebSocket 简介 WebSocket是一种在单个TCP连接上进行全双工通信的协议。WebSocket使得客户端和服务器之间的数据交换变得更加简单&#xff0c;允许服务端主动向客户端推送数据。在WebSocket API中&#xff0c;浏览器和服务器只需要…

基于html+css的图展示98

准备项目 项目开发工具 Visual Studio Code 1.44.2 版本: 1.44.2 提交: ff915844119ce9485abfe8aa9076ec76b5300ddd 日期: 2020-04-16T16:36:23.138Z Electron: 7.1.11 Chrome: 78.0.3904.130 Node.js: 12.8.1 V8: 7.8.279.23-electron.0 OS: Windows_NT x64 10.0.19044 项目…

C++入门

文章目录 &#x1f600;1. 命名空间&#x1f604;1.1 命名空间定义&#x1f604;1.2 命名空间使用 &#x1f60a;2. 输入和输出&#x1f609;3. 缺省参数&#x1fae0;3.1 缺省参数概念&#x1fae0;3.2 缺省参数分类 &#x1f62c;4. 函数重载&#x1f644;4.1 函数重载概念&a…