我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Spring Boot:实现MyBatis动态创建表

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Spring Boot:实现MyBatis动态创建表

在有些应用场景中,我们会有需要动态创建和操作表的需求。

比如因为单表数据存储量太大而采取分表存储的情况,又或者是按日期生成日志表存储系统日志等等。这个时候就需要我们动态的生成和操作数据库表了。

而我们都知道,以往我们使用MyBatis是需要提前生成包括Model,Mapper和XML映射文件的,显然因为动态生成和操作表的需求一开始表都是不存在的,所以也就不能直接通过MyBatis连接数据库来生成我们的数据访问层代码并用来访问数据库了。

MyBatis提供了动态SQL,我们可以通过动态SQL,传入表名等信息然组装成建表和操作语句。

本小节中实现的案例中每个用户都会有一个自己日志表,我们的设计 思路就是在新创建用户的时候,根据用户的信息 创建一个日志存储表,表名是根据用户的 id 来创建,首先是控制中新增用户:

@Controller@RequestMapping("/user")public class UserController {    @Autowired    private IUserService userService;    @PostMapping(value="/add")    public Object addUser(@RequestBody User user) {        return userService.addUser(user);    }}

然后用户的操作IUserService实现定义如下:

@Service("userService")public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IUserService {@Resource    private UserMapper userMapper;    @Resource    private UserLogMapper userLogMapper;@Override    @Transactional    public User addUser(User user) {        // 插入        userMapper.saveUser(user);        // 添加用户时,创建日志存储表        Integer id = user.getId();        //定义用户日志表表名        String tableName = "t_user_log_" + id;        //查询表是否存在        if (userLogMapper.existTable(tableName) > 0) {            //删除用户对应的日志表            userLogMapper.dropTable(tableName);        }        //新创建表        userLogMapper.createTable(tableName);        return user;    }}

UserMapper 就是操作用户数据相关的,这里使用的是新增用户的数据:

@Mapperpublic interface UserMapper extends BaseMapper<User> {    int saveUser(@Param("user") User user);}

对应的xml

DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="flutter.dio.model.mapper.UserMapper">    <insert id="saveUser"  useGeneratedKeys="true" keyProperty="id">        insert into t_user(name,password,age)        values(#{user.name},#{user.password},#{user.age})    insert>mapper>

用户新建成功后,再根据用户的id定义表名,然后创建新的日志表:

UserLogMapper 是用户日志操作使用Mapper ,定义如下:

public interface UserLogMapper {    //保存用户的日志     int insert(@Param("tableName")String tableName, @Param("userLog") UserLog userLog);        List<UserLog> selectAll(@Param("tableName")String tableName);    int existTable(@Param("tableName")String tableName);        int dropTable(@Param("tableName")String tableName);        int createTable(@Param("tableName")String tableName);}

UserLogMapper对应的xml核心内容如下:

DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="flutter.dio.model.mapper.UserLogMapper">    <resultMap id="BaseResultMap" type="flutter.dio.model.entity.UserLog">        <id column="id" jdbcType="BIGINT" property="id"/>        <result column="user_name" jdbcType="VARCHAR" property="userName"/>        <result column="operation" jdbcType="VARCHAR" property="operation"/>        <result column="method" jdbcType="VARCHAR" property="method"/>        <result column="params" jdbcType="VARCHAR" property="params"/>        <result column="time" jdbcType="BIGINT" property="time"/>        <result column="ip" jdbcType="VARCHAR" property="ip"/>    resultMap>    <sql id="Base_Column_List">        id, user_name, operation, method, params, time, ip    sql><insert id="insert" parameterType="flutter.dio.model.entity.UserLog">        insert into ${tableName} (id, user_name, operation,      method, params, time,      ip)        values (#{userLog.id,jdbcType=BIGINT}, #{userLog.userName,jdbcType=VARCHAR},                #{userLog.operation,jdbcType=VARCHAR},                #{userLog.method,jdbcType=VARCHAR}, #{userLog.params,jdbcType=VARCHAR}, #{userLog.time,jdbcType=BIGINT},                #{userLog.ip,jdbcType=VARCHAR})    insert><select id="selectAll" resultMap="BaseResultMap">        select        <include refid="Base_Column_List"/>        from ${tableName}    select>    <select id="existTable" parameterType="String" resultType="Integer">        select count(*)        from information_schema.TABLES        where table_name = #{tableName}    select>        <update id="dropTable">        DROP TABLE IF EXISTS ${tableName}    update>        <update id="createTable" parameterType="String">        CREATE TABLE ${tableName}        (            `id`        bigint(20) NOT NULL AUTO_INCREMENT COMMENT '编号',            `user_name` varchar(50)   DEFAULT NULL COMMENT '用户名',            `operation` varchar(50)   DEFAULT NULL COMMENT '用户操作',            `method`    varchar(200)  DEFAULT NULL COMMENT '请求方法',            `params`    varchar(5000) DEFAULT NULL COMMENT '请求参数',            `time`      bigint(20) NOT NULL COMMENT '执行时长(毫秒)',            `ip`        varchar(64)   DEFAULT NULL COMMENT 'IP地址',            PRIMARY KEY (`id`)        ) ENGINE=InnoDB AUTO_INCREMENT=2897 DEFAULT CHARSET=utf8 COMMENT='用户操作日志';    update>mapper>

上述代码中包括两部分内容,一部分是对表的操作 创建 与 删除,另一部分是对表中的数据的操作,保存用户的日志数据与查询用户的日志数据,都需要将用户对应的日志表名做为参数查询。

来源地址:https://blog.csdn.net/zl18603543572/article/details/129334086

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Spring Boot:实现MyBatis动态创建表

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Spring Boot如何动态创建Bean示例代码

前言本文主要给大家介绍了关于Spring Boot动态创建Bean的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。SpringBoot测试版本:1.3.4.RELEASE参考代码如下:package com.sp
2023-05-31

spring boot动态生成接口怎么实现

本篇内容主要讲解“spring boot动态生成接口怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“spring boot动态生成接口怎么实现”吧!在某些业务场景中,我们只需要业务代码中定
2023-06-21

Spring Boot实现动态更新任务的方法

前言SpringBoot 实现动态 Job,可以通过 API 动态变更 cron。原生的 Job 实现起来很简单,只要用注解 @Scheduled(cron=xxxxxx) 来实现就可以了,但是要实现动态更改 cron ,就需要做点其他的了
2023-05-31

jQuery如何实现动态创建元素?

jQuery动态创建元素jQuery提供了动态创建元素的能力,用于丰富用户交互和创建动态页面。通过$()函数创建新元素,并使用append()添加到DOM。可设置属性、样式和事件处理程序。动态创建元素的好处包括动态页面、简化的DOM操作、代码可重用性、动画和过渡,以及避免直接操作DOM。
jQuery如何实现动态创建元素?
2024-04-08

rabbitmq动态创建队列怎么实现

RabbitMQ提供了一种动态创建队列的方式,可以通过以下步骤实现:配置RabbitMQ服务器:确保RabbitMQ服务器已正确安装和配置。创建一个连接:使用RabbitMQ的客户端库,如pika(Python)或amqplib(Java
2023-10-23

IDEA下创建SpringBoot+MyBatis+MySql项目实现动态登录与注册功能

一、搭建SpringBoot项目 1.1、file ——> new ——> project——> Spring Initializr——> next——> next——> next——> finish 注意选择包依赖关系二、springbo
2022-05-20

IDEA下创建SpringBoot+MyBatis+MySql项目实现动态登录与注册功能

IDEA下创建SpringBoot+MyBatis+MySql项目实现动态登录与注册功能https://mp.weixin.qq.com/s/urpCwcPztBjjxYdWVwhofg IDEA下创建SpringBoot+MyBatis+MySql项目实现动

	IDEA下创建SpringBoot+MyBatis+MySql项目实现动态登录与注册功能
2016-07-13

Python使用Matplotlib实现创建动态图形

Python使用Matplotlib创建动态图形是一项强大的功能,可以交互式地探索数据。通过导入Matplotlib库并遵循步骤,您可以创建和自定义动态图形。Matplotlib提供了交互功能,如缩放、平移和旋转,以及添加注释的能力。动态图形的优点包括交互性、可定制性和开源。它们广泛应用于数据可视化、科学计算、金融分析以及教育和研究领域。
Python使用Matplotlib实现创建动态图形
2024-04-02

C#动态创建数组的实现过程

本篇内容主要讲解“C#动态创建数组的实现过程”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#动态创建数组的实现过程”吧!C#动态创建数组在实际开发中是十分实用的功能实现,那么C#动态创建数组是
2023-06-17

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录