说明:基于 MyBatis 有很多第三方功能插件,这些插件可以完成数据操作方法的封装、数据库逆向工程的生成等 。
tkMapper
和 MyBatis-plus
都是基于 MyBatis 提供的第三方插件,功能类似,下面介绍 tkMapper 的使用 。
简介tkMapper 就是一个 MyBatis 插件,基于 MyBatis 提供很多工具,提高开发效率,主要有以下两个功能 。
- 提供针对单表通用的数据库操作方法
- 逆向工程(根据数据表自动生成实体类、Dao 接口、Mapper 映射文件)
MyBatis 基础环境
tkMapper 的使用需要基于 MyBatis 。
- 创建 Spring Boot 项目,选中 Lombok、Spring Web、MyBatis Framework、MySQL Driver 依赖
- application.yml 配置文件中配置相关信息
spring:datasource:driver-class-name: com.mysql.jdbc.Driverurl: jdbc:mysql://localhost:3306/springdb?serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=UTF-8username: rootpassword: luismybatis:type-aliases-package: com.luis.beansmapper-locations: classpath:mappers/*Mapper.xml
注意:配置后,手动创建 beans 和 mappers 文件夹
- 创建 dao 文件夹,在启动类上添加 dao 的包扫描器
@MapperScan(basePackages = {"com.luis.dao"})
tkMapper 环境搭建
- 添加依赖
<!-- tkMapper --><dependency><groupId>tk.mybatis</groupId><artifactId>mapper-spring-boot-starter</artifactId><version>2.1.5</version></dependency>
如果自己在 maven 仓库中搜索,注意搜索关键词:mapper starter
文章插图
PS:添加后,注意手动刷新 pom
- 更换启动类上 dao 包的包扫描器来源,不使用原先的
@MapperScan
,要使用新添加的 tkMapper 的 @MapperScan
import tk.mybatis.spring.annotation.MapperScan;@SpringBootApplication@MapperScan(basePackages = {"com.luis.dao"}) //使用tkMapper的包扫描器注解public class SpringbootTkMapperDemoApplication {public static void main(String[] args) {SpringApplication.run(SpringbootTkMapperDemoApplication.class, args);}}
PS:注意注解的包来源 import tk.mybatis.spring.annotation.MapperScan
- 以上,tkMapper 环境已经搭建完成
tkMapper 对数据的通用操作
tkMapper 提供针对单表通用的数据库操作方法 。
数据准备1. 创建数据库表
DROP TABLE IF EXISTS `users`;CREATE TABLE `users`(`user_id` int(11) NOT NULL AUTO_INCREMENT,`user_name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,`user_pwd` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,`user_realname` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,`user_img` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,PRIMARY KEY (`user_id`) USING BTREE) ENGINE = InnoDB AUTO_INCREMENT = 3 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Compact;
2. 创建实体类
@Data@NoArgsConstructor@AllArgsConstructor@Table(name = "users") //数据库表名和实体类类名不一致需要指定映射关系!public class User {@Id //指定主键private Integer userId;private String userName;private String userPwd;private String userRealname;private String userImg;}
3. 创建 Dao 接口【重点】注意:创建的 Dao 接口需要继承 tkMapper 中提供的
Mapper
和
MySqlMapper
两个接口,这两个接口提供了对单表的通用操作 。
public interface UserDao extends Mapper<User>, MySqlMapper<User> {}
可选优化策略【建议使用】:
经验总结扩展阅读
-
从实际出发实实在在做事情的成语意思是什么 从实际出发实实在在做事情的意思
-
哈里王子|查尔斯心真累!为了让哈里适时地沉默,违心向小儿子递出橄榄枝
-
-
-
-
-
-
-
-
-
-
拾伍公子|天问一号不断传回火星图片,“火星男孩”的谎言被识破,人们醒悟
-
因为国内一“低调”面霜,因为廉价被小看,用后效果不输一线大牌!
-
-
-
-
-
-
-