百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

Spring Boot整合MybatisPlus和Druid

ztj100 2025-05-08 08:10 5 浏览 0 评论

在Java中,我比较ORM熟悉的只有HibernateMybatis,其他的并未实践使用过,在这二者之间我更喜欢Mybatis,因为它精简、灵活(毕竟我是上年纪的程序员,喜欢自己写SQL)。

刚才有提到Mybatis,但是这里的重点是介绍Mybatis-Plus,它是Mybatis的增强版,如果要了解Mybatis的细节的话请点击这里

简介

据MyBatis-Plus官网介绍,MyBatis-Plus(简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。这看上去挺香的,所以必须得尝尝。
这里涉及到的环境、组件如下:

  • MariaDB 10.3.10
  • Windows 10
  • IntelliJ IDEA 2019.3.1
  • 64 bit JDK 1.8.0_231
  • Spring Boot 2.2.3.RELEASE
  • Lombok 1.18.10
  • Knife4j 2.0.1
  • Mybatis-plus 3.3.0
  • Druid

Spring Boot 整合Mybatis-Plus

我之前一直是直接用的Mybatis,但是作为喜欢偷懒的人,当然得想办法来提高我们的效率,所以就想着用Mybatis-Plus来省去一些单表的CRUD操作再结合MyBatis-Plus配套的AutoGenerator代码生成器,就能为我们节省不少时间。

引入依赖包

首先,我们得引入Mybatis-Plusmariadb-java-client等几个包:

<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 -->
       <dependency>
           <groupId>com.github.xiaoymin</groupId>
           <artifactId>knife4j-spring-boot-starter</artifactId>
           <version>2.0.1</version>
       </dependency>
       <!-- https://mvnrepository.com/artifact/com.baomidou/mybatis-plus-boot-starter -->
       <dependency>
           <groupId>com.baomidou</groupId>
           <artifactId>mybatis-plus-boot-starter</artifactId>
           <version>3.3.0</version>
       </dependency>

       <!-- https://mvnrepository.com/artifact/org.mariadb.jdbc/mariadb-java-client -->
       <dependency>
           <groupId>org.mariadb.jdbc</groupId>
           <artifactId>mariadb-java-client</artifactId>
           <version>2.5.3</version>
       </dependency>

application.yml配置我们的数据库连接信息

spring:
  datasource:
    driver-class-name: org.mariadb.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/nacos_config?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true
    username: root
    password: root
    minimum-idle: 5
    maximum-pool-size: 50
    auto-commit: true
    idle-timeout: 30000
    max-lifetime: 1800000
    connection-timeout: 30000
    connection-test-query: SELECT 1

这里我新建一个名为User的实体,具体属性如下:

@Data
@Builder
@TableName("users")
public class User {
    private String username;
    private String password;
    private int enabled;
}

新建一个UserMapper接口:

public interface UserMapper extends BaseMapper<User> {
}

在我们的启动类加上@MapperScan来指定我们的Mapper扫描目录:

@MapperScan("com.eyiadmin.demo.mapper")
我新建一个单元测试,来试试我们的UserMapperselectList:

@RunWith(SpringRunner.class)
@SpringBootTest
public class UserTests {
    @Autowired
    private UserMapper userMapper;

    @Test
    public void testUser() {
        List<User> userList = userMapper.selectList(null);
        userList.forEach(System.out::println);
    }
}

会看到Mybatis-Plus为我取出的数据:

2020-01-20 09:44:14.125 TRACE org.apache.ibatis.logging.jdbc.BaseJdbcLogger.trace(BaseJdbcLogger.java:149) 2CNU7X5OLAUE004 --- [           main] c.e.d.m.U.selectList                     : <==    Columns: username, password, enabled
2020-01-20 09:44:14.125 TRACE org.apache.ibatis.logging.jdbc.BaseJdbcLogger.trace(BaseJdbcLogger.java:149) 2CNU7X5OLAUE004 --- [           main] c.e.d.m.U.selectList                     : <==        Row: nacos, $2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu, 1
2020-01-20 09:44:14.131 DEBUG org.apache.ibatis.logging.jdbc.BaseJdbcLogger.debug(BaseJdbcLogger.java:143) 2CNU7X5OLAUE004 --- [           main] c.e.d.m.U.selectList                     : <==      Total: 1
User(username=nacos, password=$2a$10$EuWPZHzz32dJN7jexM34MOeYirDdFAZm2kuWj7VEOJhhZkDrxfvUu, enabled=1)

我们再试试Mybatis-Plus为什么封装的Insert:

@Test
    public void TestUserInsert() {
        int row = userMapper.insert(User.builder().password("aaaa").username("bbbb").enabled(1).build());
        Assert.assertEquals(row, 1);
    }

可以看到日志:

2020-01-20 09:51:32.021 DEBUG org.apache.ibatis.logging.jdbc.BaseJdbcLogger.debug(BaseJdbcLogger.java:143) 2CNU7X5OLAUE004 --- [           main] c.e.d.m.U.insert                         : ==>  Preparing: INSERT INTO users ( username, password, enabled ) VALUES ( ?, ?, ? ) 
2020-01-20 09:51:32.036 DEBUG org.apache.ibatis.logging.jdbc.BaseJdbcLogger.debug(BaseJdbcLogger.java:143) 2CNU7X5OLAUE004 --- [           main] c.e.d.m.U.insert                         : ==> Parameters: bbbb(String), aaaa(String), 1(Integer)

其他高端操作请阅读相关文档
https://mp.baomidou.com/guide/quick-start.html

Spring Boot整合Druid数据库连接池

在Spring Boot 2.X默认使用了HikariCP作为数据库连接池,据说hikariCP性能最高(hikariCP>druid>dbcp>c3p0),但是我更喜欢Druid全面的功能和毫不逊色的性能。
开撸吧,首先当然还是引入我们的需要的Druid依赖包:

<!-- https://mvnrepository.com/artifact/com.alibaba/druid-spring-boot-starter -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.1.21</version>
</dependency>

接下来就是修改我们的的application.yml配置:

spring:
  datasource:
    driver-class-name: org.mariadb.jdbc.Driver
    url: jdbc:mysql://127.0.0.1:3306/nacos_config?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true
    username: root
    password: root
    ### 连接池配置
    druid:
      initial-size: 50
      max-active: 200
      min-idle: 50
      max-wait: 50
      validation-query: SELECT 1

可以看到我们的日志信息为:

2020-01-20 10:14:54.581  INFO com.alibaba.druid.pool.DruidDataSource.close(DruidDataSource.java:2003) 2CNU7X5OLAUE004 --- [extShutdownHook] c.a.d.p.DruidDataSource                  : {dataSource-1} closing ...
2020-01-20 10:14:54.691  INFO com.alibaba.druid.pool.DruidDataSource.close(DruidDataSource.java:2075) 2CNU7X5OLAUE004 --- [extShutdownHook] c.a.d.p.DruidDataSource                  : {dataSource-1} closed

现在我们增加一个Controller来获取Druid的监控数据:

@RestController
public class DruidStatController {
    @GetMapping("/druid/status")
    public Object druidStat(){
        // DruidStatManagerFacade#getDataSourceStatDataList 该方法可以获取所有数据源的监控数据,除此之外 DruidStatManagerFacade 还提供了一些其他方法,你可以按需选择使用。
        return DruidStatManagerFacade.getInstance().getDataSourceStatDataList();
    }
}

访问
http://localhost:8080/druid/status
可以得到一个json:

[{
	"Identity": 1914285129,
	"Name": "DataSource-1914285129",
	"DbType": "mysql",
	"DriverClassName": "org.mariadb.jdbc.Driver",
	"URL": "jdbc:mysql://127.0.0.1:3306/nacos_config?useUnicode=true&characterEncoding=UTF-8&allowMultiQueries=true",
	"UserName": "root",
	"FilterClassNames": [],
	"WaitThreadCount": 0,
	"NotEmptyWaitCount": 0,
	"NotEmptyWaitMillis": 0,
	"PoolingCount": 50,
	"PoolingPeak": 50,
	"PoolingPeakTime": "2020-01-20T02:26:22.466+0000",
	"ActiveCount": 0,
	"ActivePeak": 0,
	"ActivePeakTime": null,
	"InitialSize": 50,
	"MinIdle": 50,
	"MaxActive": 200,
	"QueryTimeout": 0,
	"TransactionQueryTimeout": 0,
	"LoginTimeout": 0,
	"ValidConnectionCheckerClassName": null,
	"ExceptionSorterClassName": null,
	"TestOnBorrow": false,
	"TestOnReturn": false,
	"TestWhileIdle": true,
	"DefaultAutoCommit": true,
	"DefaultReadOnly": null,
	"DefaultTransactionIsolation": null,
	"LogicConnectCount": 0,
	"LogicCloseCount": 0,
	"LogicConnectErrorCount": 0,
	"PhysicalConnectCount": 50,
	"PhysicalCloseCount": 0,
	"PhysicalConnectErrorCount": 0,
	"DiscardCount": 0,
	"ExecuteCount": 0,
	"ExecuteUpdateCount": 0,
	"ExecuteQueryCount": 0,
	"ExecuteBatchCount": 0,
	"ErrorCount": 0,
	"CommitCount": 0,
	"RollbackCount": 0,
	"PSCacheAccessCount": 0,
	"PSCacheHitCount": 0,
	"PSCacheMissCount": 0,
	"StartTransactionCount": 0,
	"TransactionHistogram": [0, 0, 0, 0, 0, 0, 0],
	"ConnectionHoldTimeHistogram": [0, 0, 0, 0, 0, 0, 0, 0],
	"RemoveAbandoned": false,
	"ClobOpenCount": 0,
	"BlobOpenCount": 0,
	"KeepAliveCheckCount": 0,
	"KeepAlive": false,
	"FailFast": false,
	"MaxWait": 50,
	"MaxWaitThreadCount": -1,
	"PoolPreparedStatements": false,
	"MaxPoolPreparedStatementPerConnectionSize": 10,
	"MinEvictableIdleTimeMillis": 1800000,
	"MaxEvictableIdleTimeMillis": 25200000,
	"LogDifferentThread": true,
	"RecycleErrorCount": 0,
	"PreparedStatementOpenCount": 0,
	"PreparedStatementClosedCount": 0,
	"UseUnfairLock": true,
	"InitGlobalVariants": false,
	"InitVariants": false
}]

我们还可以打开stat-view-servlet,需要加入如下配置:

spring:
 datasource:
 druid:
 stat-view-servlet:
 enabled: true
 login-username: admin
 login-password: admin


这是启动后,访问
http://localhost:8080/druid/index.html
页面就会跳转到登录页面,输入我们配置的用户名和密码admin/admin:




可以看到
Druid提供的功能是比较全面的,另外在第三张图可以看到我们的相关参数,大家也可以参照这个来配置连接池。

MyBatis-Plus的代码生成器

Mybatis有Generator工具为我们提高编码效率,MyBatis-Plus也不示弱,它也提供有MyBatis-Plus AutoGenerator 。在上面的简单实体只有3个属性,假如有几十个属性怎么办呢?这时候AutoGenerator就可以帮我们一个大忙。首先引入所需包:


<!-- https://mvnrepository.com/artifact/com.baomidou/mybatis-plus-generator -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-generator</artifactId>
            <version>3.3.0</version>
        </dependency>
<!-- https://mvnrepository.com/artifact/org.apache.velocity/velocity-engine-core -->
<dependency>
    <groupId>org.apache.velocity</groupId>
    <artifactId>velocity-engine-core</artifactId>
    <version>2.1</version>
</dependency>


具体使用方式,可以去`mybatis-plus`官网查看详细教程

Knife4j的使用

这里我引入了Knife4j包:

<!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger2 -->
        <dependency>
            <groupId>com.github.xiaoymin</groupId>
            <artifactId>knife4j-spring-boot-starter</artifactId>
            <version>2.

新建一个SwaggerConfiguration类配置我们的Swagger:

@Configuration
@EnableSwagger2
@EnableKnife4j
@Import(BeanValidatorPluginsConfiguration.class)
public class SwaggerConfiguration {
    @Bean("createRestApi")
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2)
                .apiInfo( new ApiInfoBuilder()
                        //页面标题
                        .title("Demo Web Api文档")
                        //创建人
                        .contact(new Contact("eyiadmin", "https://springfox.github.io/springfox/", "eyiadmin@163.com"))
                        .version("1.0")
                        .description("Demo Web Api文档")
                        .build())
                .select()
                //API接口所在的包位置
                .apis(RequestHandlerSelectors.basePackage("com.eyiadmin.demo.controller"))
                .paths(PathSelectors.any())
                .build();

    }

}

新建一个名为UserControllerController:

@RequestMapping("/v1/user")
@RestController
@Api(tags = "User API展示")
public class UserController {

    @Autowired
    UserMapper userMapper;

    @GetMapping("/list")
    public ResponseResult<?> getUserList()
    {
        return ResponseResult.success(userMapper.selectList(null));
    }
}

启动起来,访问localhost:8080/doc.html:


调用我们的接口,可以看到
Druid监控到了我们SQL语句的执行情况


过于Swagger也可以看看我之前的一篇文章
Spring Boot集成Swagger

相关推荐

再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香

背景最近,栈长发现某些国内的开源项目都使用到了Knife4j技术,看名字就觉得很锋利啊!...

Spring Boot自动装配黑魔法:手把手教你打造高逼格自定义Starter

如果你是SpringBoot深度用户,是否经历过这样的痛苦:每个新项目都要重复配置Redis连接池,反复粘贴Swagger配置参数,在微服务架构中为统一日志格式疲于奔命?本文将为你揭开Spring...

Spring Boot(十五):集成Knife4j(spring boot 集成)

Knife4j的简介Knife4j是一个集Swagger2和OpenAPI3为一体的增强解决方案,它的前身是上一篇文章中介绍的swagger-bootstrap-ui。swagger-bootstra...

swagger-bootstrap-ui:swagger改进版本,界面更美观易于阅读

swagger作为一款在线文档生成工具,用于自动生成接口API,避免接口文档和代码不同步,但原生的界面不是很友好,下面介绍一款改进版本swagger-bootstrap-ui,界面左右侧布局,可以打开...

界面美观功能强大,终于可以告别单调的swagger ui了——knife4j

介绍knife4j是为JavaMVC框架集成Swagger生成Api文档的增强解决方案(在非Java项目中也提供了前端UI的增强解决方案),前身是swagger-bootstrap-ui,取名kni...

从 0 到 1 实战 Spring Boot 3:手把手教你构建高效 RESTful 接口

从0到1实战SpringBoot3:手把手教你构建高效RESTful接口在微服务架构盛行的今天,构建高效稳定的RESTful接口是后端开发者的核心技能。SpringBoot凭...

SpringBoot动态权限校验终极指南:3种高赞方案让老板主动加薪!

“上周用这套方案重构权限系统,CTO当着全组的面摔了祖传代码!”一位脉脉匿名网友的血泪经验:还在用硬编码写Shiro过滤器?RBAC模型搞出200张表?是时候用SpringSecurity+动态路...

一个基于 Spring Boot 的在线考试系统

今天推荐一款超级美观的在线考试系统,感兴趣可以先去预览地址看看该项目。在线Demo预览,http://129.211.88.191,账户分别是admin、teacher、student,密码是ad...

SpringBoot API开发的十大专业实践指南

在SpringBoot应用开发领域,构建高效、可靠的API需遵循系统化的开发规范。本文结合实战编码示例,详细解析10项关键开发实践,助您打造具备工业级标准的后端接口。一、RESTful...

震碎认知!将原理融会贯通到顶点的SpringBoot实战项目

SpringBoot是什么?我们知道,从2002年开始,Spring一直在飞速的发展,如今已经成为了在JavaEE(JavaEnterpriseEdition)开发中真正意义上的标准,但...

Spring Boot 整合 Knife4j 实现接口文档编写?

Knife4j增强版的SwaggerUI实现,在Knife4j中提供了很多功能并且用户体验也随之有了很大的提升。Knife4j主要基于Swagger2.0构建的,主要的用途就是在SpringBo...

前端同事老是说swagger不好用,我用了knife4j后,同事爽得不行

日常开发当中,少不了前端联调,随着协同开发的发展,前端对接口要求也变得越来越高了。所以我使用了knife4j,同事用完觉得太舒服了。knife4j简介:Knife4j...

一个基于spring boot的Java开源商城系统

前言一个基于springboot的JAVA开源商城系统,是前后端分离、为生产环境多实例完全准备、数据库为b2b2c商城系统设计、拥有完整下单流程和精美设计的java开源商城系统https://www...

再见 Swagger!国人开源了一款超好用的 API 文档生成框架真香

Knife4j是为JavaMVC框架集成Swagger生成Api文档的增强解决方案,前身是swagger-bootstrap-ui,取名kni4j是希望她能像一把匕首一样小巧,轻量,并且功能强悍!...

Spring Boot整合MybatisPlus和Druid

在Java中,我比较ORM熟悉的只有...

取消回复欢迎 发表评论: