前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >springboot+mybatis动态创建数据表和删除数据库表

springboot+mybatis动态创建数据表和删除数据库表

作者头像
知识浅谈
发布2021-09-27 11:19:57
3.1K0
发布2021-09-27 11:19:57
举报
文章被收录于专栏:分享学习

关于动态创建删除数据库表一共包含三个步骤,

  1. 引入依赖
  2. 动态创建
  3. 动态删除

前提自己先创建一个springboot的项目

第一步: 引入相关依赖(操作数据库的三剑客)

1. pom中mysql三剑客依赖

代码语言:javascript
复制
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>2.1.4</version>
</dependency>
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid-spring-boot-starter</artifactId>
    <version>1.1.9</version>
</dependency>

第二步:动态建表{自定义表明,字段}

1. controlle

代码语言:javascript
复制
 @RequestMapping("/createTable")  //动态创建表
    public void test2(){
        String tableName = "t2";      //mybatis中#() 占位符,对应的变量会自动加上引号   $()  拼接符,对应的变量不会自动加上引号
        String name = "name";     //表中字段名字
        testService.test12(tableName,name);//创建表
        return;
    }

2. service

代码语言:javascript
复制
    void test12(String tableName,String name);

3. serviceimpl

代码语言:javascript
复制
    @Override
    public void test12(String tableName,String name) {
        testMapper.test2(tableName,name);
        return;
    }

4. mappe

代码语言:javascript
复制
    void test2(@Param("tableName") String tableName,@Param("name") String name);

5. mapper.xml

代码语言:javascript
复制
<!--这个注意是用${} 因为$这个符号是拼接的意思,而#{}是占位符,会自动把变量的值两边加上引号-->
<update id="test2" parameterType="java.lang.String">
    CREATE TABLE ${tableName}(
        id int NOT NULL AUTO_INCREMENT PRIMARY KEY ,
        ${name} varchar(10) NOT null
    )
</update>

第三步:动态删除数据表

1. controlle

代码语言:javascript
复制
    @RequestMapping("/deleteTable")  //动态删除表
    public void deletetable(){
        String tableName = "t2";
        testService.test3(tableName);
        return;
    }

2. service

代码语言:javascript
复制
    void test3(String tableName);

3. serviceimp

代码语言:javascript
复制
    @Override
    public void test3(String tableName) {
        testMapper.test3(tableName);
    }

4. mappe

代码语言:javascript
复制
    void test3(@Param("tableName") String tableName);

5. mapper.xml

代码语言:javascript
复制
<update id="test3" parameterType="java.lang.String">
    DROP TABLE IF EXISTS ${tableName}
</update>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/09/06 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 第一步: 引入相关依赖(操作数据库的三剑客)
  • 第二步:动态建表{自定义表明,字段}
  • 第三步:动态删除数据表
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档