spring Boot学习笔记(通用Mapper的使用)
使用Mybatis框架编写持久层代码时,有时我们只需要单表的操作,但如果手写的话就会产生一些机械重复的工作,而通用Mapper的出现帮我们解决了这个问题。
我使用的通用Mapper是巨佬abel533写的框架,这个框架提供了极其方便的MyBatis单表的增删改查,可以让我们不必在单表操作的编写上浪费多少时间。
通用Mapper的使用步骤
1.要使用通用Mapper需要先导入依赖
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper-spring-boot-starter</artifactId>
<version>2.0.3</version>
</dependency>
2.编写配置文件
在resource目录下新建application.properties文件
#服务器相关配置
server.port=80
server.servlet.context-path=/learn
#数据库连接信息
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/数据库名
spring.datasource.username=root
spring.datasource.password=****
3.编写启动类
package com.learn;
//声明该注解是springboot的引导类
@SpringBootApplication
@MapperScan("com.learn.mapper")//注册通用mapper
public class MySpringBootApplication {
//main方法是程序的入口
public static void main(String[] args) {
//run方法,表示运行SpringBoot的引导类,参数就是SpringBoot的引导类字节码对象
SpringApplication.run(MySpringBootApplication.class);
}
}
4.编写实体类
package com.learn.domain;
/**
* User实体类
*/
//告知通用Mapper要对哪张表进行操作
@Table(name = "user")
public class User implements Serializable {
//告知通用Mapper此属性对应表中的主键
@Id
//告知通用Mapper此属性是自增长的
@KeySql(useGeneratedKeys = true)
private Integer id;
private String username;
private Date birthday;
private String sex;
private String address;
//忽略此属性,不作为查询条件
@Transient
private String test;
}
5.新建UserMapper
package com.learn.mapper;
public interface UserMapper extends Mapper<User> {
//Mapper只需要继承tk.mybatis.mapper.common.Mapper<T>这个接口,通用Mapper就会自动帮我们生成Mybatis的单表的增删改查。
}
到这里通用Mapper就编写完了,是不是特别方便快捷,下面我们来测试一下这些方法。
5.编写测试类
@RunWith(SpringRunner.class)
@SpringBootTest(classes = MySpringBootApplication.class)
public class UserMapper2Test {
@Autowired
private UserMapper userMapper;
//因为我懒,这里只写了一个根据主键查询,和一个根据User对象中的非空属性查询
@Test
public void TestMethod(){
int id = 41;
String username = "老王";
User user = userMapper.selectByPrimaryKey(id);
User user2 = new User();
user2.setUsername(username);
//根据User的非空属性查询
User user1 = userMapper.selectOne(user2);
System.out.println(user1);
System.out.println(user);
}
}
我自己还编写了service来测试事务,事务的使用方式和之前一样,只需要在方法上加@Transactional注解即可。
如有错漏,欢迎指正!
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 后端思维之高并发处理方案
· 理解Rust引用及其生命周期标识(下)
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· 2025成都.NET开发者Connect圆满结束
· 后端思维之高并发处理方案
· 千万级大表的优化技巧
· 在 VS Code 中,一键安装 MCP Server!
· 10年+ .NET Coder 心语 ── 继承的思维:从思维模式到架构设计的深度解析