做六个网站静态页多少钱wordpress加上预约系统
文章目录
- 一. 什么是MyBatis
 - 二. MyBatis操作数据库步骤(使用注解)
 - 创建工程
 - 创建数据库
 - 创建对应实体类
 - 配置数据库连接字符串
 - 写持久层代码
 - 单元测试
 
- 三. MyBatis基础操作 使用注解
 - 打印日志
 - 参数传递
 - 增
 - 删
 - 改
 - 查
 
一. 什么是MyBatis

 
 简单来说 MyBatis 是更简单完成程序和数据库交互的框架,也就是更简单的操作和读取数据库⼯具
二. MyBatis操作数据库步骤(使用注解)

创建工程
创建springboot⼯程,并导⼊ mybatis的起步依赖、mysql的驱动包
 
 Mybatis 是⼀个持久层框架, 具体的数据存储和数据操作还是在MySQL中操作的, 所以需要添加MySQL驱动
 
创建数据库
CREATE TABLE `userinfo` (`id` int(11) NOT NULL AUTO_INCREMENT,`username` varchar(127) NOT NULL,`password` varchar(127) NOT NULL,`age` tinyint(4) NOT NULL,`gender` tinyint(4) DEFAULT '0' COMMENT '1-男 2-女 0-默认',`phone` varchar(15) DEFAULT NULL,`delete_flag` tinyint(4) DEFAULT '0' COMMENT '0-正常, 1-删除',`create_time` datetime DEFAULT CURRENT_TIMESTAMP,`update_time` datetime DEFAULT CURRENT_TIMESTAMP,PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb4;
 
创建对应实体类

配置数据库连接字符串
spring:datasource:url: jdbc:mysql://127.0.0.1:3306/mybatis_test?characterEncoding=utf8&useSSL=falseusername: rootpassword: rootdriver-class-name: com.mysql.cj.jdbc.Driver
 
修改数据库名称, 密码即可
写持久层代码

 
Mybatis的持久层接⼝规范⼀般都叫 XxxMapper
@Mapper注解:表⽰是MyBatis中的Mapper接⼝
 程序运⾏时, 框架会⾃动⽣成接⼝的实现类对象(代理对象),并给交Spring的IOC容器管理
@Select注解:代表的就是select查询,也就是注解对应⽅法的具体实现内容
单元测试

 
 
 选择想要测试的方法, 就会在Test中对应的文件帮我们创建测试方法
 
- 需要我们添加@SpringBootTest注解, 该测试类在运行时, 就会自动加载Spring的运行环境
 - 通过@Autowired这个注解, 注入我们要测试的类, 就可以开始测试了

 

运行成功
三. MyBatis基础操作 使用注解
打印日志
在Mybatis当中我们可以借助⽇志, 查看到sql语句的执⾏、执⾏传递的参数以及执⾏结果
mybatis:configuration: # 配置打印 MyBatis⽇志log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
 

参数传递
在方法中添加参数, 将方法中的参数, 传给SQL, 在SQL语句中使用**#{ }**来接收
 
 测试:
 
 
- 如果方法形参只有一个参数, 那么#{} 中的属性名可以随便写
 - 如果是多个参数, 那么就要求参数名和属性名一致

 - 可以通过@Param()设置别名, 来映射到对应的属性名
此时, 只会按照id2来映射, id会失效 
增

 
 如果使用@Param
 
 想要获取到自增字段:
 使用@Options(useGeneratedKeys = true, keyProperty = “id”)
 
 
 将JDBC的useGeneratedKeys方法拿到的数据库中生成的主键, 赋给keyProperty指定的属性中
 测试:
 

删

改

查

 
 观察日志发现, 数据库将后面字段的数据传回来了, 但是在打印userInfo对象时, 却没有接收到
 原因分析:
 当⾃动映射查询结果时,MyBatis 会获取结果中返回的列名并在 Java 类中查找相同名字的属性(忽略
 ⼤⼩写)。 这意味着如果发现了 ID 列和 id 属性,MyBatis 会将列 ID 的值赋给 id 属性
 但是由于规范性, 命名的时候, 字段名和属性名 不可能完全一致
 ** 办法一: 起别名**
 
 
 成功接收
 ** 办法二: 结果映射**
 使用@Results({@Result(column = ..., property = ...), @Result(column = ..., property = ...)...})注解, 来映射字段和属性
 
 
 映射成功
 但是每当我们写个sql都需要加上这个映射关系
 复用映射关系:
 如果其他SQL, 也希望可以复⽤这个映射关系, 可以给这个Results定义⼀个id
 
 其他的sql使用@ResultMap注解来复用这个映射关系即可
 
 办法三: 开启驼峰命名
 加上配置:
mybatis:configuration: map-underscore-to-camel-case: true #配置驼峰⾃动转换 

 代码中无需做任何处理
 
 映射成功
