文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

SpringBoot整合MyBatis完全使用注解方式定义Mapper

2024-12-03 04:00

关注

环境:springboot2.3.11 + MyBatis3.5.6

依赖

  1.  
  2.   org.springframework.boot 
  3.   spring-boot-starter-web 
  4.  
  5.  
  6.   org.mybatis.spring.boot 
  7.   mybatis-spring-boot-starter 
  8.   2.1.4 
  9.  
  10.  
  11.   com.github.pagehelper 
  12.   pagehelper-spring-boot-starter 
  13.   1.3.0 
  14.  

 应用配置

  1. pagehelper: 
  2.   helperDialect: mysql 
  3.   reasonable: true 
  4.   pageSizeZero: true 
  5.   offsetAsPageNum: true 
  6.   rowBoundsWithCount: true 
  7. --- 
  8. mybatis: 
  9.   type-aliases-package: com.pack.domain 
  10.   configuration: 
  11.     lazy-loading-enabled: false 
  12.     aggressive-lazy-loading: false    
  13.     logImpl: org.apache.ibatis.logging.stdout.StdOutImpl 
  14.     mapUnderscoreToCamelCase: true 

 以上配置请查看官方文档说明:

分页配置:

mybatis配置:

启动类添加Mapper扫描

  1. @SpringBootApplication 
  2. @MapperScan({"com.pack.mapper"}) 
  3. public class SpringBootMyBatisApplication { 
  4.  
  5.   public static void main(String[] args) { 
  6.     SpringApplication.run(SpringBootMyBatisApplication.class, args); 
  7.   } 
  8.  

 添加@MapperScan注解后,就不需要在每个Mapper上添加@Mapper注解了。

核心处理类:

MapperScannerRegistrar.java

  1. public class MapperScannerRegistrar implements ImportBeanDefinitionRegistrar, ResourceLoaderAware { 
  2. }   

 ImportBeanDefinitionRegistrar类的主要功能就是用来动态注册Bean的。很多的第三方库都是通过实现该接口来动态注册Bean,比如EnableFeignClients用来扫描指定包下所有类上带有@FeignClient注解的类。

ImportBeanDefinitionRegistrar需要结合ClassPathBeanDefinitionScanner使用ClassPathBeanDefinitionScanner用来扫描那些类需要被动态注册为Bean。比如Mybatis中使用AutoConfiguredMapperScannerRegistrar来动态注册具有@Mapper注解的类。

Mapper接口定义

  1. public interface UsersMapper { 
  2.      
  3.    
  4.   @Select("SELECT * FROM t_users"
  5.   @Results(id = "users", value = {@Result(property = "name"column = "name", javaType = String.class),  
  6.   @Result(property = "password"column = "password")}) 
  7.   List findAll() ; 
  8.      
  9.    
  10.   @Select("SELECT * FROM t_users WHERE id = #{id}"
  11.   @ResultMap("users"
  12.   Users findById(String id) ; 
  13.      
  14.    
  15.   @Insert("insert into t_users values(#{id}, #{password}, #{username})"
  16.   int saveUsers(Users users) ; 
  17.      
  18.    
  19.   @Update("UPDATE t_users SET username = #{username}, password = #{password} WHERE id = #{id}"
  20.   int updateUsers(Users users) ; 
  21.      
  22.    
  23.   @Delete("DELETE FROM t_users where id = #{id}"
  24.   int deleteById(String id) ; 
  25.      
  26.    
  27.   @SelectProvider(type = UsersProvider.class, method = "selectLikeUsers"
  28.   @ResultMap("users"
  29.   List selectLikeUsers(Users users) ; 
  30.      
  31.    
  32.   @UpdateProvider(type = UsersProvider.class, method = "updateByProvider"
  33.   int updateByProvider(@Param("users") Users users) ; 

 说明:

@Results注解添加了id属性后,在其他的方法中可以通过@ResultMap("users")来引用。

@*Provider用来动态的定义SQL语句。

  1. public class UsersProvider { 
  2.  
  3.   public String selectLikeUsers(Users users) { 
  4.     StringBuilder sql = new StringBuilder("SELECT * FROM t_users t where 1=1 "); 
  5.       if(users.getUsername() != null && users.getUsername().trim().length() > 0) { 
  6.          sql.append(String.format("and t.username like '%s'""%" + users.getUsername() + "%")); 
  7.       } 
  8.     return sql.toString(); 
  9.     } 
  10.      
  11.   public String updateByProvider(@Param("users") Users users) { 
  12.     SQL sql = new SQL() ; 
  13.     sql.UPDATE("t_users"
  14.       .SET("username = #{users.username}""password = #{users.password}"
  15.       .WHERE("id = #{users.id}") ; 
  16.     return sql.toString() ; 
  17.   } 
  18.      

 单元测试

  1. @RunWith(SpringRunner.class) 
  2. @SpringBootTest 
  3. public class UsersMapperTest { 
  4.      
  5.   @Resource 
  6.   private UsersMapper usersMapper ; 
  7.      
  8.   @Test 
  9.   public void testFindAll() { 
  10.     Page page = PageHelper.startPage(1, 2) ; 
  11.     usersMapper.findAll() ; 
  12.     System.out.println(page.getResult()) ; 
  13.     System.out.println(page.getTotal() + "\n" + page.getPages()) ; 
  14.   } 
  15.      
  16.   @Test 
  17.   public void testFindById() { 
  18.     System.out.println(usersMapper.findById("1")) ; 
  19.   } 
  20.      
  21.   @Test 
  22.   public void testSaveUsers() { 
  23.     Users users = new Users() ; 
  24.     users.setId("4") ; 
  25.     users.setPassword("123456") ; 
  26.     users.setUsername("zhangsan") ; 
  27.     System.out.println(usersMapper.saveUsers(users)) ; 
  28.   } 
  29.      
  30.   @Test 
  31.   public void testUpdateUser() { 
  32.     Users users = new Users() ; 
  33.     users.setId("3") ; 
  34.     users.setPassword("111111") ; 
  35.     users.setUsername("zhangsan") ; 
  36.     System.out.println(usersMapper.updateUsers(users)) ; 
  37.   } 
  38.      
  39.   @Test 
  40.   public void testDeleteById() { 
  41.     System.out.println(usersMapper.deleteById("3")) ; 
  42.   } 
  43.      
  44.   @Test 
  45.   public void testSelectLikeUsers() { 
  46.     Users users = new Users() ; 
  47.     users.setUsername("gu") ; 
  48.     System.out.println(usersMapper.selectLikeUsers(users)) ; 
  49.   } 
  50.      
  51.   @Test 
  52.   public void testUpdateByProvider() { 
  53.     Users users = new Users() ; 
  54.     users.setId("2") ; 
  55.     users.setPassword("111111") ; 
  56.     users.setUsername("guest") ; 
  57.     System.out.println(usersMapper.updateByProvider(users)) ; 
  58.   } 
  59.      

 完毕!!!

 

来源:今日头条内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯