SpringBoot整合Mysql+Mybatis-Plus

pom

        
        
            mysql
            mysql-connector-java
            8.0.21
            runtime
        
        
        
            com.alibaba
            druid-spring-boot-starter
            1.2.8
        
        
        
            com.baomidou
            mybatis-plus-boot-starter
            3.4.1
        

yml

spring:
  # JDBC 配置(驱动类自动从url的mysql识别,数据源类型自动识别)
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/test?characterEncoding=UTF-8&useUnicode=true&useSSL=false&tinyInt1isBit=false&allowPublicKeyRetrieval=true&serverTimezone=Asia/Shanghai
    username: root
    password: 123456
  druid:
    # 全局druid参数,绝大部分值和默认保持一致。(不清楚含义不要乱设置)
    # 初始化大小,最小,最大
    initial-size: 5
    min-idle: 5
    maxActive: 20
    # 配置获取连接等待超时的时间
    maxWait: 60000
    # 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒
    timeBetweenEvictionRunsMillis: 60000
    # 配置一个连接在池中最小生存的时间,单位是毫秒
    minEvictableIdleTimeMillis: 300000
	#用来检测连接是否有效的sql
    validationQuery: SELECT 1
	#申请连接时检测空闲时间,根据空闲时间再检测连接是否有效
    testWhileIdle: true
	#申请连接时直接检测连接是否有效.申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能
    testOnBorrow: false
	#归还连接时检测连接是否有效.归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能
    testOnReturn: false
    # 打开PSCache,并且指定每个连接上PSCache的大小
    poolPreparedStatements: true
    maxPoolPreparedStatementPerConnectionSize: 20
    # 通过connectProperties属性来打开mergeSql功能;慢SQL记录
    connectionProperties: druid.stat.mergeSql\=true;druid.stat.slowSqlMillis\=5000
#mybatis-plus配置 
mybatis-plus:
  #配置Mapper映射文件
  mapper-locations: classpath*:mapper/*.xml
  global-config:
    banner: false
	#设置逻辑删除(mybatis-plus的 删除 会成为逻辑删除 查询 方法自动过滤删除数据)
    db-config:
	  #逻辑删除字段
      logic-delete-field: isDel
	  #删除值
      logic-delete-value: 0
	  #未删除值
      logic-not-delete-value: 1
  configuration:
	#下划线驼峰命名
    map-underscore-to-camel-case: true
        #开启日志打印
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

分页插件

import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @Description MybatisPlus配置类
 */
@Configuration
public class MybatisPlusConfig {

    /**
     * @Description 分页插件
     */
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }

}

新增拦截器(这只是一个示例,需要根据自己的数据库字段进行修改)

import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.executor.Executor;
import org.apache.ibatis.mapping.MappedStatement;
import org.apache.ibatis.mapping.SqlCommandType;
import org.apache.ibatis.plugin.*;
import org.springframework.stereotype.Component;

import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Properties;

/**
 * mybatis拦截器,自动注入创建人、创建时间、修改人、修改时间
 */
@Slf4j
@Component
@Intercepts({ @Signature(type = Executor.class, method = "update", args = { MappedStatement.class, Object.class }) })
public class MybatisInterceptor implements Interceptor {

	@Override
	public Object intercept(Invocation invocation) throws Throwable {
		MappedStatement mappedStatement = (MappedStatement) invocation.getArgs()[0];
		String sqlId = mappedStatement.getId();
		log.debug("------sqlId------" + sqlId);
		SqlCommandType sqlCommandType = mappedStatement.getSqlCommandType();
		Object parameter = invocation.getArgs()[1];
		log.debug("------sqlCommandType------" + sqlCommandType);
		if (parameter == null) {
			return invocation.proceed();
		}
		if (SqlCommandType.INSERT == sqlCommandType) {
			Field[] fields = getAllFields(parameter);
			for (Field field : fields) {
				log.debug("------field.name------" + field.getName());
				try {
					if ("creator".equals(field.getName())) {
                                                //开启对私有属性的操作
						field.setAccessible(true);
						Object local_createBy = field.get(parameter);
						field.setAccessible(false);
						if (local_createBy == null || local_createBy.equals("")) {
							field.setAccessible(true);
							//放入当前登录用户的id
							field.set(parameter, "创建人");
							field.setAccessible(false);
						}
					}
				} catch (Exception e) {
					e.printStackTrace();
				}
			}
		}else if(SqlCommandType.UPDATE== sqlCommandType){
                    //修改的操作
                }
		return invocation.proceed();
	}

	@Override
	public Object plugin(Object target) {
		return Plugin.wrap(target, this);
	}

	@Override
	public void setProperties(Properties properties) {
		// TODO Auto-generated method stub
	}

	/**
	 * 获取类的所有属性,包括父类
	 */
	public static Field[] getAllFields(Object object) {
		Class clazz = object.getClass();
		List fieldList = new ArrayList<>();
		while (clazz != null) {
			fieldList.addAll(new ArrayList<>(Arrays.asList(clazz.getDeclaredFields())));
			clazz = clazz.getSuperclass();
		}
		Field[] fields = new Field[fieldList.size()];
		fieldList.toArray(fields);
		return fields;
	}

}

你可能感兴趣的:(数据库,mysql,mybatis,java,sql)