springboot快速集成mybatis-plus的详细教程
简介
Mybatis-Plus(简称MP)是一个Mybatis的增强工具,在Mybatis的基础上只做增强不做改变,为简化开发、提高效率而生。这是官方给的定义,关于mybatis-plus的更多介绍及特性,可以参考mybatis-plus官网。那么它是怎么增强的呢?其实就是它已经封装好了一些crud方法,我们不需要再写xml了,直接调用这些方法就行,就类似于JPA。
springBoot快速集成mybatis-plus
一、pom文件引入mybatis-plus依赖
org.springframework.boot spring-boot-starter-web org.projectlombok lombok true mysql mysql-connector-java 5.1.25 com.baomidou mybatis-plus-boot-starter 3.1.0 org.springframework.boot spring-boot-starter-test test
注:这里最主要的是mybatis-plus-boot-starter依赖,其他依赖都是基本的
二、基础配置application.properties
#mysql数据库 spring.datasource.url=jdbc:mysql://127.0.0.1:3306/springbootdemo?characterEncoding=UTF-8&allowMultiQueries=true&serverTimezone=GMT%2B8 spring.datasource.username=root spring.datasource.password=111111 spring.datasource.driver-class-name=com.mysql.jdbc.Driver #mybatis #开启驼峰 mybatis.configuration.map-underscore-to-camel-case=true #打印日志 mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl #mybatis-plus配置 mybatis-plus.mapper-locations=classpath*:/mappers/*.xml #主键类型0:"数据库ID自增",1:"用户输入ID",2:"全局唯一ID(数字类型唯一ID)",3:"全局唯一IDUUID"; mybatis-plus.global-config.id-type=0 #字段策略0:"忽略判断",1:"非NULL判断"),2:"非空判断" mybatis-plus.global-config.field-strategy=1 #驼峰下划线转换 mybatis-plus.global-config.db-column-underline=true
三、MybatisPlusConfig
/** *MybatisPlus配置类 */ @EnableTransactionManagement @Configuration @MapperScan(basePackages="com.example.demo.mapper") publicclassMybatisPlusConfig{ /** *分页插件 */ @Bean publicPaginationInterceptorpaginationInterceptor(){ returnnewPaginationInterceptor(); } }
四、测试
实体类主键使用@TableId(value="id",type=IdType.AUTO)指定类型
@TableField(exist=false):表示该属性不为数据库表字段,但又是必须使用的。
@Data publicclassSysUserimplementsSerializable{ privatestaticfinallongserialVersionUID=1L; /** *主键 */ @TableId(value="id",type=IdType.AUTO) privateIntegerid; /** *用户名 */ privateStringusername; /** *密码 */ privateStringpassword; /** *电话 */ privateStringphone; /** *邮箱 */ privateStringemail; /** *创建时间 */ privateDatecreateDate; /** *更新时间 */ privateDateupdateDate; /** *sys_user */ }
新建SysUserMapper继承BaseMapper
publicinterfaceSysUserMapperextendsBaseMapper{ }
测试
@Autowired privateSysUserMappersysUserMapper; /** *插入 */ @Test publicvoidinsert(){ SysUsersysUser=newSysUser(); sysUser.setPhone("18787878787"); sysUser.setPassword("123456"); sysUser.setUsername("root"); sysUser.setCreateDate(newDate()); sysUser.setUpdateDate(newDate()); sysUserMapper.insert(sysUser); } /** *分页查询 */ @Test publicvoidselectByPage(){ Pagepage=newPage(1,1); IPagep=sysUserMapper.selectPage(page,newQueryWrapper ().eq("password","123456")); System.out.println(p.getRecords()); }
分页一般使用
ListgetCallLogList(ApiLogDTOdto,Pagepage);mapper IPage getCallLogList(ApiLogDTOdto);IService serviceImpl @Override publicIPage getCallLogList(ApiLogDTOdto){ Page page=newPage(dto.getCurrent(),dto.getSize()); List list=apiLogMapper.getCallLogList(dto,page); page.setRecords(list); returnpage; } controller @PostMapping("/call/log") @ApiOperation("api调用日志列表") publicIPage callLog(@ModelAttributeApiLogDTOdto){ returnsysService.getCallLogList(dto); }
附上目录结构
总结
到此这篇关于springboot快速集成mybatis-plus的详细教程的文章就介绍到这了,更多相关springboot集成mybatis-plus内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。