Springboot入门之集成MybatisPlus

这篇具有很好参考价值的文章主要介绍了Springboot入门之集成MybatisPlus。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

MybatisPlus是一个 Mybatis的增强工具,在Mybatis的基础上只做增强不做改变,为简化开发、提高效率而生。 

1.添加依赖【pom.xml】

        <!-- mysql db -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>

        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.5.1</version>
        </dependency>

        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-annotation</artifactId>
            <version>3.5.1</version>
            <scope>compile</scope>
        </dependency>

        <!--代码生成器-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.5.1</version>
        </dependency>

2.配置数据源信息[application.yml]

# 数据源配置
spring:
	datasource:
		url: jdbc:mysql://xxx:3306/xxx?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&useSSL=false&allowMultiQueries=true
		username: xxx
		password: xxxxx
		dbcp2:
			validation-query: SELECT 1
			time-between-eviction-runs-millis: 18800
		hikari:
			max-lifetime: 30000
			validation-timeout: 3000
			connection-timeout: 18800
			idle-timeout: 18800

# sql日志输出配置
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

3.MybatisPlus拦截器配置

配置后MybatisPlus增加功能生效【如分页等】。

@Configuration
@MapperScan(value = {"com.{company}.{model}.mapper"})
public class MybatisPlusConfig {

    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }

}

4.编写XxxMapper

extends BaseMapper<XxxDo>;

/**
 * <p>
 * Mapper 接口
 * </p>
 *
 * @author ocean
 * @since 2023-03-17
 */
@Mapper
public interface XxxMapper extends BaseMapper<XxxDo> {

}

5.编写XxxService

extends ServiceImpl<XxxMapper, XxxDo>

@Service
public class XxxServiceImpl extends ServiceImpl<XxxMapper, XxxDo> implements XxxService {

    @Resource
    private XxxMapper XxxMapper;

    public void test(){
        XxxMapper.insert(new XxxDo());
        XxxMapper.deleteById(1L);
        XxxMapper.updateById(new XxxDo());
        XxxMapper.selectPage(new Page<XxxDo>(1, 10), new QueryWrapper<>());
    }
}

6.Wapper查询

1.查询Wrapper
QueryWrapper<XxxDo> queryWrapper = Wrappers.query();
LambdaQueryWrapper<XxxDo> lambdaQueryWrapper = Wrappers.lambdaQuery();

2.更新Wrapper
UpdateWrapper<XxxDo> updateWrapper = Wrappers.update();
LambdaUpdateWrapper<XxxDo> lambdaUpdateWrapper = Wrappers.lambdaUpdate();

OR 查询

LambdaQueryWrapper<Xxx> lambdaQueryWrapper = Wrappers.lambdaQuery();
lambdaQueryWrapper.and(wrapper -> wrapper.like(Xxx::xx, 'xxx').or().like(Xxx::xxx, 'xxx'));

7.配置安全

7.1)生成数据源加密信息

import com.baomidou.mybatisplus.core.toolkit.AES;

public class JdbcEncodeUtil {

    public static final String URL = "jdbc:mysql://xxx:3306/xxx?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&useSSL=false&allowMultiQueries=true";
    public static final String USERNAME = "xxx";
    public static final String PASSWORD = "xxxx";

    public static void main(String[] args) {
        // 生成 16 位随机 AES 密钥
        String randomKey = AES.generateRandomKey();

        // 随机密钥加密
        String url = AES.encrypt(URL, randomKey);
        String username = AES.encrypt(USERNAME, randomKey);
        String password = AES.encrypt(PASSWORD, randomKey);

        System.out.println("randomKey = " + randomKey);
        System.out.println("url = " + url);
        System.out.println("username = " + username);
        System.out.println("password = " + password);

    }

}

7.2)配置数据源加密【application.yml】

// 加密配置 mpw: 开头紧接加密内容( 非数据库配置专用 YML 中其它配置也是可以使用的 )
spring:
  datasource:
    url: mpw:qRhvCwF4GOqjessEB3G+a5okP+uXXr96wcucn2Pev6Bf1oEMZ1gVpPPhdDmjQqoM
    password: mpw:Hzy5iliJbwDHhjLs1L0j6w==
    username: mpw:Xb+EgsyuYRXw7U7sBJjBpA==

7.3)配置秘钥

7.3.1)jar包运行 java -jar xxx.jar --mpw.key=1111111111111 

7.3.2)IDEA 设置 Program arguments,如下图:

Springboot入门之集成MybatisPlus

7.4)实现原理

SpringBoot 提供修改Spring环境后置处理器【EnvironmentPostProcessor】,允许在应用程序之前操作环境属性值。

public class SafetyEncryptProcessor implements EnvironmentPostProcessor {
    public SafetyEncryptProcessor() {
    }

    public void postProcessEnvironment(ConfigurableEnvironment environment, SpringApplication application) {
        String mpwKey = null;
        Iterator var4 = environment.getPropertySources().iterator();

        while(var4.hasNext()) {
            PropertySource<?> ps = (PropertySource)var4.next();
            if (ps instanceof SimpleCommandLinePropertySource) {
                SimpleCommandLinePropertySource source = (SimpleCommandLinePropertySource)ps;
                mpwKey = source.getProperty("mpw.key");
                break;
            }
        }

        if (StringUtils.isNotBlank(mpwKey)) {
            HashMap<String, Object> map = new HashMap();
            Iterator var15 = environment.getPropertySources().iterator();

            while(true) {
                PropertySource ps;
                do {
                    if (!var15.hasNext()) {
                        if (CollectionUtils.isNotEmpty(map)) {
                            environment.getPropertySources().addFirst(new MapPropertySource("custom-encrypt", map));
                        }

                        return;
                    }

                    ps = (PropertySource)var15.next();
                } while(!(ps instanceof OriginTrackedMapPropertySource));

                OriginTrackedMapPropertySource source = (OriginTrackedMapPropertySource)ps;
                String[] var8 = source.getPropertyNames();
                int var9 = var8.length;

                for(int var10 = 0; var10 < var9; ++var10) {
                    String name = var8[var10];
                    Object value = source.getProperty(name);
                    if (value instanceof String) {
                        String str = (String)value;
                        if (str.startsWith("mpw:")) {
                            map.put(name, AES.decrypt(str.substring(4), mpwKey));
                        }
                    }
                }
            }
        }
    }
}

8.自动填充功能

8.1)实现元对象处理器接口【com.baomidou.mybatisplus.core.handlers.MetaObjectHandler】

@Slf4j
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {

    @Override
    public void insertFill(MetaObject metaObject) {
        log.info("start insert fill ....");
        // 起始版本 3.3.3(推荐)
        this.strictInsertFill(metaObject, "createTime", () -> new Date(), Date.class);
        // 起始版本 3.3.0(推荐使用)
        // this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now());
        //
        // this.fillStrategy(metaObject, "createTime", LocalDateTime.now());
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        log.info("start update fill ....");
        // 起始版本 3.3.3(推荐)
        this.strictUpdateFill(metaObject, "updateTime", () -> new Date(), Date.class);
        // 起始版本 3.3.0(推荐)
        // this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now());
        // 也可以使用(3.3.0 该方法有bug)
        // this.fillStrategy(metaObject, "updateTime", LocalDateTime.now()); // 也可以使用(3.3.0 该方法有bug)
    }

}

8.2)注解填充字段【@TableField(fill = FieldFill.INSERT/.INSERT_UPDATE/.UPDATE) 】

/**
 * 基础 [entity]
 *
 * @author ocean.liu
 */
@Data
public class BaseEntity {

    /**
     * 创建时间
     */
    @TableField(value = "create_time", fill = FieldFill.INSERT)
    protected Date createTime;

    /**
     * 修改时间
     */
    @TableField(value = "update_time", fill = FieldFill.INSERT_UPDATE)
    protected Date updateTime;

    /**
     * 是否删除
     */
    @TableField(value = "is_deleted")
    protected Integer isDeleted;

}

9.代码生成器

public class CodeGenerator {


    /**
     * 数据库链接地址
     **/
    private static final String JDBC_URL_MAN = "jdbc:mysql://xxxxx:3306/xxx?useUnicode=true&characterEncoding=UTF-8";
    /**
     * 数据库登录账号
     **/
    private static final String JDBC_USER_NAME = "xx";
    /**
     * 数据库登录密码
     **/
    private static final String JDBC_PASSWORD = "xxxx";


    public static void main(String[] args) {
        String dir = "\\xx\\xxx";
        String tablePrefix = "t_";
        List<String> tables = new ArrayList<>();
        tables.add("t_doctor");

        FastAutoGenerator.create(JDBC_URL_MAN, JDBC_USER_NAME, JDBC_PASSWORD)
                .globalConfig(builder -> {
                    builder.author("ocean")                                                           // 作者
                            .outputDir(System.getProperty("user.dir") + dir + "\\src\\main\\java")    // 输出路径(写到java目录)
                            .enableSwagger()                                                          // 开启swagger
                            .commentDate("yyyy-MM-dd")
                            .fileOverride();                                                          // 开启覆盖之前生成的文件

                })
                .packageConfig(builder -> {
                    builder.parent("com.{company}")
                            .moduleName("{model}")
                            .entity("entity")
                            .service("service")
                            .serviceImpl("serviceImpl")
                            .controller("api")
                            .mapper("mapper")
                            .xml("mapper")
                            .pathInfo(Collections.singletonMap(OutputFile.mapperXml, System.getProperty("user.dir") + dir + "\\src\\main\\resources\\mapper"));
                })
                .strategyConfig(builder -> {
                    builder.addInclude(tables)
                            .addTablePrefix(tablePrefix)
                            .serviceBuilder()
                            .formatServiceFileName("%sService")
                            .formatServiceImplFileName("%sServiceImpl")
                            .entityBuilder()
                            .enableLombok()
                            .logicDeleteColumnName("deleted")
                            .enableTableFieldAnnotation()
                            .controllerBuilder()
                            .formatFileName("%sController")
                            .enableRestStyle()
                            .mapperBuilder()
                            .enableBaseResultMap()               // 生成通用的resultMap
                            .superClass(BaseMapper.class)
                            .formatMapperFileName("%sMapper")
                            .enableMapperAnnotation()
                            .formatXmlFileName("%sMapper");
                })
                //.templateEngine(new FreemarkerTemplateEngine()) // 使用Freemarker引擎模板,默认的是Velocity引擎模板
                .execute();
    }

}

MyBatisPlus官方指南文章来源地址https://www.toymoban.com/news/detail-409799.html

到了这里,关于Springboot入门之集成MybatisPlus的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Docker安装ClickHouse22.6.9.11并与SpringBoot、MyBatisPlus集成

    上一篇文章CentOS6.10上离线安装ClickHouse19.9.5.36并修改默认数据存储目录记录了在旧版的操作系统上直接安装低版本 ClickHouse (脱胎于俄罗斯头号搜索引擎的技术)的过程,开启远程访问并配置密码; 其实通过 Docker 运行 ClickHouse 是我在2022年10月左右在虚拟机上实验的,当时

    2024年02月09日
    浏览(40)
  • 一个springboot项目的jenkins持续集成配置

    目录 1.项目基本情况 2.jenkins的下载 1)  安装jdk 2)下载、启动和配置jenkins 3. 启动Jenkins 4. 安装Jenkins插件 5. 重启jenkins 6.jenkins工具的配置 1) jdk的路径配置 7.创建springboot项目的持续集成任务 1)  新建项目 2)代码拉取 3)  打包项目 4)启动jar程序 5)解决jenkins构建结束后终止所

    2024年02月10日
    浏览(42)
  • Springboot 集成 RocketMq(入门)

    Linux 安装 RocketMq-CSDN博客 Springboot 集成 RocketMQ(进阶-消息)-CSDN博客

    2024年02月05日
    浏览(38)
  • ElasticSearch完整入门及springboot集成

    Elaticsearch,简称为es,es是一个开源的高扩展的分布式全文检索引擎,它可以近乎实时的存储、检索数据;本身扩展性很好,可以扩展到上百台服务器,处理PB级别(大数据时代)的数据。es也使用java开发并使用Lucene作为其核心来实现所有索引和搜索的功能,但是它的目的是 通过

    2024年02月09日
    浏览(47)
  • 若依集成mybatisplus报错找不到xml

    引用:https://blog.csdn.net/qq_65080131/article/details/136677276 MybatisPlusAutoConfiguration 中可以知道,系统会自动配置SqlSessionFactory,,但是,当你有自定义的 SqlSessionFactory ,,就会出问题,,,, 若依中的 SqlSessionFactory 不是 MybatisSqlSessionFactory 所以需要,将SqlSessionFactory 换成, MybatisS

    2024年04月27日
    浏览(51)
  • IDEA集成EasyCode插件,快速生成自定义mybatisplus代码

    在idea插件中,搜索EasyCode插件,下载并进行安装。  easyCode插件可以修改作者名称,即生成代码后,注释中自动添加相应作者的姓名。  Type Mapper指的是生成mapper.xml文件中数据库中的字段和java中代码的字段以及生成mybatis数据之间的类型转换。最常见的形式如下,也就是java中的

    2024年02月06日
    浏览(42)
  • SpringBoot与MybatisPlus MybatisPlus

    MyBatis-Plus(简称 MP)是一个MyBatis的增强工具,在MyBatis的基础上只做增强不做改变,为简化开发、提高效率而生。 MyBatisPlus的愿景是成为MyBatis最好的搭档,就像魂斗罗中的1P、2P,基友搭配,效率翻倍。 官方网址:MyBatis-Plus  1、创建SpringBoot项目,添加MyBatisPlus起步依赖 2、在

    2024年02月12日
    浏览(34)
  • SpringBoot与MybatisPlus SpringBoot

    Spring是一个非常优秀的轻量级框架,以IOC(控制反转)和AOP(面向切面)为思想内核,极大简化了JAVA企业级项目的开发。 虽然Spring的组件代码是轻量级的,但它的配置却是重量级的。使用Spring进行项目开发需要在配置文件中写很多代码,所有这些配置都代表了开发时的损耗

    2024年02月07日
    浏览(36)
  • SpringBoot整合Druid、Mybatis、MybatisPlus以及MybatisPlus的使用

    1)引入jar包 2)在application.yml中 注意: initialization-mode: always 第一次用过之后注释掉,或者将其改成never 3).启动项目,访问:http://127.0.0.1:8080/druid/          用户名:admin/密码:123456(在配置文件中有) ps:还记得mybatis中的sqlSessionFactory要传入一个dataSource吗?所以我们先学习

    2024年02月12日
    浏览(42)
  • 【MybatisPlus快速入门】—— 进阶入门

    Mybatis 框架之所以能够简化数据库操作,是因为他内部的映射机制,通过自动映射,进行数据的封装,我们只要符合映射规则,就可以快速高效的完成 SQL 操作的实现 既然 MybatisPlus 是基于 Mybatis 的增强工具,所以也具有这样的映射规则 1.1.1 自动映射 表名和实体类名映射 - 表

    2023年04月23日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包