MyBatis---初阶

一、MyBatis作用

是一种更简单的操作和读取数据库的工具。

二、MyBatis准备工作

1、引入依赖
2、配置Mybatis(数据库连接信息)
3、定义接口

@Mapper注解是MyBatis中用来标识接口为Mapper接口的注解。在MyBatis中,Mapper接口是用来定义SQL映射的接口,通过@Mapper注解标识的接口会被MyBatis自动扫描并注册为Mapper接口,从而可以在MyBatis的配置文件中进行配置和使用。

4、准备数据

建表规范:字段全部小写,单词之间使用_分割;必须有id、create_time、update_time3个字段。

5、创建对应的实体类

三、操作数据库--注解实现

1、查询所有用户

(1)实现代码

(2)测试

生成的测试代码,@SpringBootTest是加载spring运行环境:

运行结果:

该结果只能看到打印的结果,不能看见sql语句、参数等信息,可以配置。

配置内容:

再次运行代码:

2、根据id查询指定用户

(1)代码实现

id=#{id},id作为参数传给sql语句,且要保证参数名也为id,可以使用@Param重命名。

(2)测试

运行结果:

3、根据id和姓名查询指定用户

(1)代码实现

(2)测试

运行结果:

4、查询存在的问题

以上图片对比可以发现:sql的运行结果和java(mybatis)运行结果有些地方不一致。Java结果是null

sql表字段:

java类成员变量:

mybatis会根据查询的结果进行对应赋值,前几个属性名是一样的,后几个不一样,导致后几个变量名无法一一对应,使得不一样的成员变量没有结果。

5、解决属性名不一致

(1)起别名

可以给数据库属性名起别名,使得和成员变量名一致。

运行结果:

(2)结果映射

对于不一样的名字,可以将数据库名和java成员变量名进行一一映射。

运行结果:

对于该映射也可以在其他方法中使用:

给该映射定义一个id名:

复用该映射关系:

运行结果:

(3)配置文件实现自动转化

实现java变量驼峰命名方式与数据库属性命名方式的自动转换。

配置内容:

此时就可以实现一一对应了,不会出现java变量为null了。

6、增加用户

(1)代码实现

(2)测试

运行结果:

思考一个问题:以上没有对id进行赋值,自动赋值时,如何获取到自增id值???

在接口方法上加上@Options注解,useGeneratedKeys会命令mybatis使用jdbc的getuseGeneratedKeys方法,取到数据库内部自增主键,默认值为false;keyProperty:指定能够唯⼀识别对象的属性

获取id值:

运行结果:

7、更新用户

(1)代码实现

(2)测试

运行结果:

8、删除用户

(1)代码实现

(2)测试

运行结果:

四、操作数据库--xml实现

定义一个接口UserInfoXmlMapper;创建UserInfoXMLMapper.xml,xml里的内容是固定的,需要修改接口路径。

配置yml:

1、查询所有用户

(1)代码实现

(2)测试

运行结果:

2、根据id查询用户

(1)代码实现

(2)测试

运行结果:

3、根据id和用户名查询用户

(1)实现代码

(2)测试

运行结果:

4、解决属性名不一致

xml实现sql操作中,依旧会存在数据库字段名和成员变量名不对应的问题,以上图片没有呈现出来是因为配置中已经实现转换了。

(1)配置文件实现自动转化

实现java变量驼峰命名方式与数据库属性命名方式的自动转换。

配置内容:

此时就可以实现一一对应了,不会出现java变量为null了。

(2)起别名

(3)结果映射

对于不一样的名字,可以将数据库名和java成员变量名进行一一映射。

5、增加用户

(1)实现代码

(2)测试

运行结果:

对于获取到自增id值的方法和注解大致一样:

运行结果:

6、更新用户

(1)实现代码

(2)测试

运行结果:

7、删除用户

(1)实现代码

(2)测试

运行结果:

相关推荐
麦兜*2 分钟前
MongoDB 6.0 新特性解读:时间序列集合与加密查询
数据库·spring boot·mongodb·spring·spring cloud·系统架构
chat2tomorrow5 分钟前
数据采集平台的起源与演进:从ETL到数据复制
大数据·数据库·数据仓库·mysql·低代码·postgresql·etl
稻草人想看远方8 分钟前
关系型数据库和非关系型数据库
数据库
考虑考虑9 分钟前
Postgerssql格式化时间
数据库·后端·postgresql
千里码aicood17 分钟前
【springboot+vue】党员党建活动管理平台(源码+文档+调试+基础修改+答疑)
java·数据库·spring boot
TDengine (老段)38 分钟前
TDengine 选择函数 Max() 用户手册
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
驾驭人生1 小时前
Asp .Net Core 系列:Asp .Net Core 集成 Hangfire+MySQL
数据库·mysql·.netcore
xhbh6661 小时前
不止是DELETE:MySQL多表关联删除的JOIN语法实战详解
数据库·mysql·程序员·mysql删除语句
不掰手腕1 小时前
在UnionTech OS Server 20 (统信UOS服务器版) 上离线安装PostgreSQL (pgsql) 数据库
linux·数据库·postgresql