springboot启动时候自动创建数据库表解决方案

首先创建一个springboot的项目
项目结构
在这里插入图片描述

  1. 导入相关依赖
    mybatis druid mysql驱动三个

        <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>
    
  2. springboot 2.3.4.Release版本配置文件配置

    
    spring:
      datasource:
    	username: root
    	password: root
    	url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=GMT%2B8
        driver-class-name: com.mysql.cj.jdbc.Driver
    	type: com.alibaba.druid.pool.DruidDataSource
    	#项目启动执行建表语句,classpath指定sql文件的位置
    	schema:
      	  - classpath:sql/init.sql
    	initialization-mode: always
    	platform: mysql
    	sql-script-encoding: UTF-8
    
    

    springboot 2.6.4版本配置文件配置(谢谢nreg的指出)

    spring: 
      sql:
        init:
          separator: ; #断句分隔符,默认为 ; 号,如果执行语句中有 存储过程 或 游标 这种 则需要更改
          encoding: UTF-8
          platform: sqlite #默认值为all 在不同数据库切换的情况下才使用 all 配置,spring boot 会自动检测当前使用的数据库
          mode: always # 初始化模式,有三个值:always:始终执行初始化、embedded:只初始化内存数据库(默认)、never:不执行初始化
          schema-locations: #表初始化语句 DDL,默认加载 schema.sql
            - classpath:sql/schema.sql
          data-locations: #数据初始化 DQL(数据查询)或 DML(数据操作),默认加载 data.sql,
            - classpath:sql/data.sql
    
  3. sql文件填写

    
    -- ----------------------------
    -- Table structure for t1
    -- ----------------------------
    DROP TABLE IF EXISTS `t1`;
    CREATE TABLE `t1`  (
      `id` int(11) NOT NULL,
      `name` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
      PRIMARY KEY (`id`) USING BTREE
    ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;
    
    -- ----------------------------
    -- Records of t1
    -- ----------------------------
    INSERT INTO `t1` VALUES (1, '1');
    INSERT INTO `t1` VALUES (2, '2');
    INSERT INTO `t1` VALUES (3, '3');
    
    SET FOREIGN_KEY_CHECKS = 1;
    
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

知识浅谈

您的支持将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值