JavaWeb开发03-Mybatis入门-基础操作-XML映射文件-动态SQL

一、Mybatis-入门

Java程序控制数据库

1.入门

定义实体类:一定要和表中的字段一一对应

配置连接数据库数据

建立Mapper层语句,来获取数据库数据以及将其封装到user的list中去。

2.配置SQL提示

为了进行查询数据库中有哪些表,所以得连接数据库

3.JDBC介绍

 4.数据库连接池

所有数据库连接池都要实现DataSource这个接口

如果要在spring框架下使用德鲁伊连接池只需要引入德鲁伊的起步依赖

5.lombok

原先实体类需要构造器以及需要get,set,重写toString

lombok只需要注解

红色的注解用的最多

首先引入lombok依赖:

然后在实体类上进行注解就行

二、Mybatis基础操作

1.删除

在mapper接口中要创建一个抽象方法并使用delete注解,括号里是删除的操作,传入的主键id

 

使用这个接口

建议保持一致

Mybatis底层MYSQL语句是怎么样的执行什么操作是看不到的,所以需要日志

不需要记,只要记住什么需要日志,mybtis加上log就会出现其配置项。

之前删除的底层:

预编译SQL

预编译的占位符导致每次输出语句一样只需要编译一次

SQL注入

而预编译会将你的输入密码整个传给password避免了SQL注入

使用#()就是使用了预编译

2.新增

Mapper中的函数

测试新增函数

主键返回

如何实现主键返回

3.更新

根据主键修改信息

更新操作的SQL语句

Mapper更新方法:

Java中的测试程序

4.查询

解决方案:

方式一:给字段起别名

方式二:通过Resulte注解

方式三:开启mybatis的驼峰命名自动映射开关
在properties中开启:

输入camel

条件查询

Mapper方法:

注意:#()不能在引号里,为了进行模糊匹配使用$拼接符,但是存在SQL注入问题,所以采用SQL的concat语句:

测试函数:

对于之前版本的SpringBoot版本使用Param注解来对应,现在内置了编译插件

三、XML映射文件

配置SQL语句可以通过注解也可以通过XML映射文件

配置XML文件语句

第一条红色区域的java包下的mapper和resource包下的xml
第二条紫色区域
第三条黄色区域

创建resource包下的xml文件目录格式:
使用新建Directory,使用斜线分割

在test或者application中使用前得配置XML文件:

固定约束是:

使用XML映射文件条件查询:
Mapper方法函数:

test中进行xml文件映射

按规范是为了让SQL语句匹配上,注解就直接匹配了

四、动态SQL

1.动态标签

<if>

使用XML映射文件

这样只传入name也会根据name进行查询,或者两个三个一个进行查询。

但是这样如果不传入name,传了gender和entrydate,前有and,SQL语法不正确

所以需要使用<where>标签,会判断里面的条件

案例

对于部门人员信息的更新,有些信息不需要更新,但之前的不使用动态标签的就必须每个参数都要传入

但是如果不传username,会多余一个,出现错误所以使用set动态标签

<foreach>

批量删除信息

mapper方法函数 :

<foreach>中的参数:

XML映射文件

测试程序:

<sql><include>

在XML映射文件中存在许多通用的语句重复使用,所以使用这组动态标签进行代码的复用

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

宝宝餐椅上亚马逊美国站要求什么认证?

大家都知道儿童餐椅是宝宝饮食的重要伙伴。它们为宝宝提供了一个舒适的环境&#xff0c;让宝宝在吃饭的时候更愉快&#xff0c;更健康。然而&#xff0c;许多家长可能不知道&#xff0c;亚马逊美国站售卖的儿童餐椅需要进行一系列严格的认证&#xff0c;以保护我们宝贝们的安全…

视频国标学习

总体介绍 GB/T28181协议&#xff0c;全名叫《安全防范视频监控联网系统信息传输、交换、控制技术要求》&#xff0c;是由中国国家标准委员会发布的一种国家级的标准。它主要对视频监控系统的各个方面做了明确的规定&#xff0c;使得不同厂商生产的视频监控设备能够相互连通&am…

Linux学习-数据库

数据库软件: 关系型数据库: Mysql Oracle SqlServer Sqlite 非关系型数据库&#xff1a; Redis NoSQL 1.数组、链表、文件、数据库 数组、链表: 内存存放数据的方式(代码运行结束、关机数据丢失) 文件、…

防范“AI换脸”风险 ZOLOZ Deeper问世

4 月 16 日&#xff0c;深度伪造&#xff08;Deepfake&#xff09;综合防控产品ZOLOZ Deeper 在北京正式发布&#xff0c;以拦截用户刷脸过程中的“AI换脸”风险&#xff0c;目前已率先应用在身份安全领域。公开资料显示&#xff0c;ZOLOZ是蚂蚁数科的科技品牌&#xff0c;以生…

ClickHouse--18--argMin() 和argMax()函数

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 argMin() 和argMax()函数业务场景使用案例1.准备表和数据&#xff1a;业务场景一&#xff1a;查看salary 最高和最小的user业务场景二&#xff1a;根据更新时间获取…

学习经验分享【32】本科/硕士开题报告、中期报告等写作经验分享

本科/硕士阶段首先就是要写开题报告&#xff0c;然后中期报告&#xff0c;这篇博文就是分享一下写报告的经验&#xff0c;避免被老师打回来。本人有丰富的写报告经验&#xff0c;有需要的朋友可添加文末联系方式与我联系。 一、本科开题报告的提纲 课题来源及研究的目的和意义…

lua学习笔记21完结篇(lua中的垃圾回收)

print("*****************************lua中的垃圾回收*******************************") text{id24,name"仙贝"} --垃圾回收关键字collectgarbag --获取当前lua占用内存数 k字节 返回值*1024就可以得到具体占用字节数 print(collectgarbage("count&…

运营商三要素验证API接口怎么对接

运营商三要素验证API接口又叫手机三要素验证API接口、运营商实名认证接口&#xff0c;这个接口是验证姓名、身份证号、手机号三者是否一致&#xff0c;返回验证结果&#xff0c;如果一致则说明三者信息匹配&#xff0c;可以有效确认当前注册用户的身份信息&#xff0c;那么运营…

系统集成项目管理工程师教程,第2章领读文字简化版来啦

上周六晚上在软考中项内进行了第2波领读&#xff0c;用18分钟时间领读了中项第3版教程的第2章&#xff0c;考虑到语音没法回放&#xff0c;迟到同学无法回听&#xff0c;所以围绕领读内容的要点&#xff0c;今天简要整理了一篇文字稿。 不过文字稿是精简版&#xff0c;如果你需…

在Vue3中如何使用H.265视频流媒体播放器EasyPlayer.js?

H5无插件流媒体播放器EasyPlayer属于一款高效、精炼、稳定且免费的流媒体播放器&#xff0c;可支持多种流媒体协议播放&#xff0c;可支持H.264与H.265编码格式&#xff0c;性能稳定、播放流畅&#xff0c;能支持WebSocket-FLV、HTTP-FLV&#xff0c;HLS&#xff08;m3u8&#…

【Origin+Python】使用External Python批量出图代码参考

目录 基本介绍环境配置官方代码示例基础代码详解我的代码效果视频进阶代码及去水印 基本介绍 origin2021后可以使用python实现批量绘图&#xff0c;一共有两种方式&#xff1a;一种是嵌入式Python&#xff0c;一种是外部Python访问Origin。详细介绍可以自己去查看&#xff0c;打…

shell变量类型

简介 环境变量 小结&#xff1a; 自定义局部变量 自定义全局变量