框架建设实战4——数据库访问组件

针对数据库客操作,我们需要借助ORM来完成数据库访问。

本章讨论如何创建一个数据库访问组件。

1.组件命名

考虑到orm的场景比较场景,且比较重要。我们将orm组件纳入到starter的组件类型里。

命名为frame-orm-starter

2.技术选型:mybatis + mybatis plus

考虑到mybatis已有现有springboot集成的组件,我们引入如下依赖:

XML 复制代码
    <dependency> 
      <groupId>org.mybatis.spring.boot</groupId>  
      <artifactId>mybatis-spring-boot-starter</artifactId> 
    </dependency>  
    <dependency> 
      <groupId>mysql</groupId>  
      <artifactId>mysql-connector-java</artifactId>  
      <scope>runtime</scope> 
    </dependency>  
    <dependency> 
      <groupId>com.baomidou</groupId>  
      <artifactId>mybatis-plus-boot-starter</artifactId> 
    </dependency>  
    <dependency> 

3.核心类和方法实现

本组件的主要逻辑,其实就是MP(mybatis-plus)已经帮我我们实现的逻辑。

本组件对普通的mybatis处理,做了一些功能增强:如分页、逻辑删除、全局乐观锁、自动填充等。

具体方法见mybatis-plus官网说明。如自动填充的配置:

XML 复制代码
mybatis-plus: 
  global-config:
    db-config:
      logic-delete-field: isDeleted # 全局逻辑删除的实体字段名
      logic-delete-value: Y # 逻辑已删除值
      logic-not-delete-value: N # 逻辑未删除值

创建一个配置类:包含如下内容:

3.1 定义插件(如分页)

java 复制代码
@Bean
    public PaginationInnerInterceptor paginationInnerInterceptor() {
        PaginationInnerInterceptor paginationInterceptor = new PaginationInnerInterceptor();
        // 设置最大单页限制数量,-1 不受限制
        paginationInterceptor.setMaxLimit(200L);
        paginationInterceptor.setDbType(DbType.MYSQL);
        // 开启 count 的 join 优化,只针对部分 left join
        paginationInterceptor.setOptimizeJoin(true);
        return paginationInterceptor;
    }

3.2 装配插件拦截器

java 复制代码
/**
     * 定义MP插件主体 MybatisPlusInterceptor
     * 使用多个功能插件需要注意顺序关系,建议使用如下顺序
     * 分页,乐观锁
     * sql 性能规范,防止全表更新与删除
     * @return
     */
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor(){
        MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
        //分页插件
        mybatisPlusInterceptor.addInnerInterceptor(paginationInnerInterceptor());
        //乐观锁
        mybatisPlusInterceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
        return mybatisPlusInterceptor;
    }

4.扩展特性

如果mybatis-plus默认的mapper方法无法满足我们的需要,还可以基于DefaultSqlInjector 进行扩展 定制的SQL 注入器。实现更多方法。如批量修改、批量添加等。

思考题:

一般情况下,公司都要求数据库表设计时,有统一的字段。比如创建时间、修改时间、创建人、修改人等。那么这些通用字段就可以通过框架规范来处理。

比如定义一个通用的BasePO 类 。业务实现的所有PO 类都要继承此基类。

java 复制代码
@Data
public class BasePO implements Serializable {

    private static final long serialVersionUID = -33333333L;
    
    /**
     * 创建时间
     */
    @TableField(fill = FieldFill.INSERT)
    private Date createTime;
    
    /**
     * 修改时间
     */
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date modifyTime;

    /**
     * 创建人
     */
    private String creator;
    
    /**
     * 修改人
     */
    private String modifier;
}

那么问题来了,这个类是要放在frame-base里呢?还是放在frame-orm-starter组件中?欢迎大家留言讨论。

相关推荐
qq_334466864 分钟前
U9补丁同步的时候报错
数据库
施嘉伟7 分钟前
KSQL Developer 测试记录
数据库·kingbase
谱度众合11 分钟前
【蛋白互作研究】邻近标记PL-MS实验指南:如何精准获取目标蛋白的基因序列?
数据库·科技·蛋白质组学·药物靶点·生物科研
麦聪聊数据21 分钟前
生成测试数据(三):从建表到 CRUD 的冷启动
数据库·sql
Awkwardx24 分钟前
MySQL数据库—MySQL复合查询
数据库·mysql
2301_8002561124 分钟前
R-Tree创建与遍历,R-Tree在4类空间查询中的应用,实现4类空间查询的各类算法[第8章]
数据库·算法·机器学习·postgresql·r-tree
十月南城24 分钟前
分布式ID选型——雪花、号段、数据库自增与时钟回拨的风险控制
数据库·分布式
老邓计算机毕设25 分钟前
SSM校园快递代取平台32618(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·校园快递代取平台
论迹29 分钟前
【Redis】-- 单线程模型
数据库·redis·缓存
悦数图数据库30 分钟前
BOSS 直聘基于悦数图数据库构建智能根因定位平台的实践
数据库·人工智能