Mybatis-Plus插件配置
yml配置
1 # Mybatis-Plus
2 mybatis-plus:
3 # 配置mapper的扫描,找到所有的mapper.xml映射文件
4 mapper-locations: com.xxx.project.biz.*.mapper.*Mapper.xml,com.xxx.project.biz.*.*.mapper.*Mapper.xml
5 #实体扫描
6 typeAliasesPackage: com.xxx.project.biz.*.entity,com.xxx.project.biz.*.*.entity
7 global-config:
8 # 数据库相关配置
9 db-config:
10 #主键类型 NONE:"数据库ID自增", INPUT:"用户输入ID", ID_WORKER:"全局唯一ID (数字类型唯一ID)", UUID:"全局唯一ID UUID", AUTO: MP自动决定;
11 id-type: id_worker
12 #字段策略 IGNORED:"忽略判断", NOT_NULL:"非 NULL 判断", NOT_EMPTY:"非空判断"
13 field-strategy: not_empty
14 #驼峰下划线转换
15 column-underline: true
16 #数据库大写下划线转换
17 capital-mode: true
18 #table-prefix: sys_
19 #逻辑删除配置
20 logic-delete-value: 1
21 logic-not-delete-value: 0
22 # 数据库类型
23 db-type: mysql
24 #刷新mapper 调试神器
25 refresh: true
26 # 原生配置
27 configuration:
28 map-underscore-to-camel-case: true
29 cache-enabled: false
30 # 打印sql日志
31 log-impl: org.apache.ibatis.logging.stdout.StdOutImpl乐观锁、逻辑删除、物流分页插件配置
1 /**
2 * MybatisPlus 扫描mapper配置 以及 插件配置
3 * @Author: xhq
4 * @Version: 1.0
5 */
6 @Configuration
7 @MapperScan({"com.xxx.project.biz.*.mapper","com.xxx.project.biz.*.*.mapper"})
8 public class MybatisPlusConfig {
9
10 /**
11 * 物理分页 插件
12 * @return
13 */
14 @Bean
15 public PaginationInterceptor paginationInterceptor() {
16 return new PaginationInterceptor();
17 }
18
19 /**
20 * 乐观锁 插件
21 * @return
22 */
23 @Bean
24 public OptimisticLockerInterceptor optimisticLockerInterceptor() {
25 return new OptimisticLockerInterceptor();
26 }
27
28 /**
29 * 逻辑删除
30 * @return
31 */
32 @Bean
33 public ISqlInjector sqlInjector() {
34 return new LogicSqlInjector();
35 }
36 }1 /**
2 * Entity基类
3 *
4 * @author xhq
5 */
6 public class BaseEntity implements Serializable {
7
8 private static final long serialVersionUID = 1L;
9
10 /** 主键id @JSONField该注解是解决Long类型太长传值前端精度丢失*/
11 @JSONField(serializeUsing= ToStringSerializer.class)
12 private Long id;
13
14 /** 创建时间 插入自动填充 */
15 @TableField(fill = FieldFill.INSERT)
16 private Date createTime;
17
18 /** 更新时间 插入和更新自动填充 */
19 @TableField(fill = FieldFill.INSERT_UPDATE)
20 private Date updateTime;
21
22 /** 备注 */
23 private String remark;
24
25 /** 逻辑删除 0:正常 1:删除 */
26 @TableLogic
27 private Integer deleted;
28
29 /** 乐观锁 */
30 @Version
31 private Integer version;
32
33 getter and setter... ...
34 }自动填充字段配置
1 /**
2 * mybatis-plus 自定义自动填充字段处理器
3 * @Author: xhq
4 * @Version: 1.0
5 */
6 @Component
7 public class MyMetaObjectHandler implements MetaObjectHandler {
8
9 @Override
10 public void insertFill(MetaObject metaObject) {
11 this.setInsertFieldValByName("createTime", new Date(), metaObject);
12 this.setInsertFieldValByName("updateTime", new Date(), metaObject);
13 }
14
15 @Override
16 public void updateFill(MetaObject metaObject) {
17 this.setUpdateFieldValByName("updateTime", new Date(), metaObject);
18 }
19 }
Mybatis-Plus插件配置的更多相关文章
- myBatis分页插件配置
由于 Apache公司发现myBatis的分页弊端,所以又研发出得补丁:PageHelper 中央仓库5.1.2版连接地址: <!-- https://mvnrepository.com/art ...
- Mybatis分页插件PageHelper的配置和使用方法
Mybatis分页插件PageHelper的配置和使用方法 前言 在web开发过程中涉及到表格时,例如dataTable,就会产生分页的需求,通常我们将分页方式分为两种:前端分页和后端分页. 前端分 ...
- 关于struts2的过滤器和mybatis的插件的分析
网上一搜,发现一篇写的非常棒的博文,就直接复制过来了,供以后复习使用. 前辈博文链接:共三篇: http://jimgreat.iteye.com/blog/1616671: http://jimgr ...
- Mybatis分页插件
mybatis配置 <!-- mybatis分页插件 --> <bean id="pagehelper" class="com.github.pageh ...
- MyBatis多数据源配置(读写分离)
原文:http://blog.csdn.net/isea533/article/details/46815385 MyBatis多数据源配置(读写分离) 首先说明,本文的配置使用的最直接的方式,实际用 ...
- Mybatis分页插件PageHelper正确的用法(网上有2篇不够科学的文章)
今天下午在Mybatis项目中.实现分页.由于我是后加入项目中的,Leader用的是PageHelper这个组件.可是我在实际使用的过程中遇到了2个大问题. 1.p=2#comments" ...
- mybatis generator 插件安装及使用
现在Mybatis特别火,但是在开发中却要经常写实体类和配置文件,会不会特别烦人,所以可以利用Mybatis的代码生成插件来生成这部分代码: 1,打开eclipse,点击Help>Softwar ...
- 使用Mapper专用的MyBatis Generator插件
使用Maven执行MBG 这里有一个完整的例子,Mybatis-Spring,下面讲解的内容出自这个例子. 使用Maven插件的一个好处是可以将Maven中的属性使用${property}形式在gen ...
- Mybatis分页插件PageHelper正确的使用方法(网上有2篇不够科学的文章)
今天下午在Mybatis项目中,实现分页.因为我是后加入项目中的,Leader用的是PageHelper这个组件,但是我在实际使用的过程中遇到了2个大问题. 1.http://www.oschina. ...
- Mybatis分页插件PageHelper使用
一. Mybatis分页插件PageHelper使用 1.不使用插件如何分页: 使用mybatis实现: 1)接口: List<Student> selectStudent(Map< ...
随机推荐
- 软件测试漫谈(web测试,自动化测试,Jmeter)
软件测试,就是一个过程或一系列过程,用来确定计算机代码完成了其应该完成的功能不执行其不该有的操作. 简单说就是找bug的过程. 测试分类 (1)按测试方式分类:静态测试.动态测试 (2) 按测试方法分 ...
- Java一些概念
1.Java先编译后解释 同一个.class文件在不同的虚拟机会得到不同的机器指令(Windows和Linux的机器指令不同),但是最终执行的结果却是相同的. 2.JDK包含JRE,JRE包含JVM, ...
- 【noi 2.7_7215】简单的整数划分问题(算法效率)
题意:问正整数n的所有划分个数. 解法:f[i][j]表示划分 i 后的每个数不大于 j 的划分数.分情况讨论:划分中每个数都小于 j,相当于每个数不大于 j- 1, 故划分数为 f[i][j-1] ...
- hdu3635 Dragon Balls
Problem Description Five hundred years later, the number of dragon balls will increase unexpectedly, ...
- AcWing 247. 亚特兰蒂斯 (线段树,扫描线,离散化)
题意:给你\(n\)个矩形,求矩形并的面积. 题解:我们建立坐标轴,然后可以对矩形的横坐标进行排序,之后可以遍历这些横坐标,这个过程可以想像成是一条线从左往右扫过x坐标轴,假如这条线是第一次扫过矩形的 ...
- 数位dp整理 && 例题HDU - 2089 不要62 && 例题 HDU - 3555 Bomb
数位dp: 数位dp是一种计数用的dp,一般就是要统计一个区间[li,ri]内满足一些条件数的个数.所谓数位dp,字面意思就是在数位上进行dp.数位的含义:一个数有个位.十位.百位.千位......数 ...
- GoAccess 监控工具
GoAccess 基本概述 简易的统计访问量的软件,官方安装教程 GoAccess 安装 # 下载包 [root@web01 ~]# wget http://tar.goaccess.io/goacc ...
- java源码之集合类ArrayList
1. ArrayList概述: ArrayList是List接口的可变数组的实现.实现了所有可选列表操作,并允许包括 null 在内的所有元素.除了实现 List 接口外,此类还提供一些方法来操作内部 ...
- docker的底层-隔离的核心
在了解底层原理之前: 说几个名词: 解耦状态: 所有东西都没有重复,任何东西都没有公用的地方. 半解耦状态:有部分共同的一起用,其他的独立 完全解耦状态: 就是各自都是独立没有重复. kvm:完全解耦 ...
- codeforces 9D(非原创)
D. How many trees? time limit per test 1 second memory limit per test 64 megabytes input standard in ...