跳至主要內容

利用Spring Boot实现MySQL数据库的自动创建,666

沉默王二约 2289 字大约 8 分钟

MySQL 的数据库操作

MySQL 安装完成并连接open in new window成功后,就可以创建数据库进行操作了。

执行 show databases; 命令可以查看当前数据库的所有数据库。

注意在 MySQL 客户端执行 SQL 语句的时候要带上分号 ; 并按下 enter 键,不然 MySQL 会认为你还没有输入完,会换一行继续等待你输入。

也就是说,分号 ; 是 MySQL 的语句结束符。

OK,像上面截图中的 information_schema、mysql、performance_schema、sys 这些都是 MySQL 自带的数据库,剩余的 cmower、codingmore、jeesite、jepf、pai_coding 等都是我本地创建的数据库,这些数据库名大家很容易就联系到某些有点名气的开源项目,比如说技术派。

二哥的 MySQL 进阶之路open in new window会结合技术派实战项目open in new window来讲解 MySQL 的基本操作。

上面截图中的 pai_coding 就是技术派项目的数据库。对技术派项目还不太了解的小伙伴可以戳下面的链接了解:

二哥的原创实战项目技术派详细介绍open in new window

创建数据库

创建数据库的语法是:

create database 数据库名;

比如说我要创建一个名为 test 的数据库,就可以执行:

create database test;

如果提示 Query OK, 1 row affected (0.02 sec),说明数据库创建成功了。

再用 show databases; 命令查看一下,就可以看到 test 数据库了。

一个小技巧:MySQL 会记忆之前输入过的命令,使用键盘上的上下箭头按键可以切换命令。

通常情况下,我们在创建数据库的时候会额外加上 if not exists,否则当数据库已经存在的时候,会报 database exists 的错误。

create database test;
ERROR 1007 (HY000): Can't create database 'test'; database exists

我们可以这样写:

create database if not exists test;
Query OK, 1 row affected, 1 warning (0.00 sec)

可以看到,SQL 语句执行成功了,但会有一个 warning 警告,这是因为数据库已经存在了,所以 MySQL 会提示我们。

切换数据库

切换数据库的语法是:

use 数据库名;

比如说我们要切换到技术派的 pai_coding 数据库,就可以执行:

use pai_coding;

如果提示 Database changed,说明切换成功了。

只有切换到技术派数据库下,我们才能对技术派数据库下面的表进行操作。

删除数据库

删除数据库的语法是:

drop database 数据库名;

比如说我们要删除 test 数据库,就可以执行:

drop database test;

是不是很简单?

但删库跑路之前,最好掐一下自己的大腿,看看自己是不是清醒着,不然后悔都来不及(😂)。

删除数据库的时候,也可以带上 if exists,这样当数据库不存在的时候,就不会报错了。

drop database if exists test;

技术派是如何创建数据库的?

技术派创建数据库是自动完成的,当项目启动的时候就会自动创建数据库。

具体实现的方法我放在了技术派的教程里,大家可以通过这个链接获取技术派实战教程。

二哥的原创实战项目技术派详细介绍open in new window

这里我做一些简单的介绍,实现源码在 ForumDataSourceInitializer 这个类中。

注意看 autoInitDatabase 方法,这里是自动创建数据库的逻辑。

private boolean autoInitDatabase() {
    // 查询失败,可能是数据库不存在,尝试创建数据库之后再次测试

    // 数据库链接
    URI url = URI.create(SpringUtil.getConfigOrElse("spring.datasource.url", "spring.dynamic.datasource.master.url").substring(5));
    // 用户名
    String uname = SpringUtil.getConfigOrElse("spring.datasource.username", "spring.dynamic.datasource.master.username");
    // 密码
    String pwd = SpringUtil.getConfigOrElse("spring.datasource.password", "spring.dynamic.datasource.master.password");
    // 创建连接
    try (Connection connection = DriverManager.getConnection("jdbc:mysql://" + url.getHost() + ":" + url.getPort() +
            "?useUnicode=true&characterEncoding=UTF-8&useSSL=false", uname, pwd);
            Statement statement = connection.createStatement()) {
        // 查询数据库是否存在
        ResultSet set = statement.executeQuery("select schema_name from information_schema.schemata where schema_name = '" + database + "'");
        if (!set.next()) {
            // 不存在时,创建数据库
            String createDb = "CREATE DATABASE IF NOT EXISTS " + database;
            connection.setAutoCommit(false);
            statement.execute(createDb);
            connection.commit();
            log.info("创建数据库({})成功", database);
            if (set.isClosed()) {
                set.close();
            }
            return true;
        }
        set.close();
        log.info("数据库已存在,无需初始化");
        return false;
    } catch (SQLException e2) {
        throw new RuntimeException(e2);
    }
}

逻辑很简单,就是根据 URL、用户名、密码创建数据库连接,客户端到服务端的连接,然后从 information_schema.schemata 表中查询数据库是否存在,如果不存在,就创建数据库。

用的是最原始的 JDBC 方式,以及一些 Spring 方面的知识,这里就不展开了。大家看代码注释应该是能懂的。

information_schema 是 MySQL 的元数据信息,数据库的信息会存放在 schemata 表中。我们可以通过终端查看到 schemata 表的结构。

这里给大家留一个作业题,如果你之前学过 Java 或者 Spring Boot 的话,可以仿照技术派的方式实现一个自动创建数据库的功能。

Java 原生

Java 原生代码需要你先下载一个 MySQL 的 JDBC 驱动,驱动的作用是让 Java 程序能够和 MySQL 数据库进行交互。

MySQL Connector/Jopen in new window

将下载的 .jar 包放到项目 classpath 下,什么是 classpath,一般就是项目的 src/main/resources 目录,或者是项目的 lib 目录。

接下来,编写一个 Java 类来连接到 MySQL 服务器,并在数据库不存在时创建它:

class DatabaseCreator {
    private static final String URL = "jdbc:mysql://localhost:3306/?useSSL=false&serverTimezone=UTC";
    private static final String USER = "root";
    private static final String PASSWORD = "Codingmore123";
    private static final String DATABASE_NAME = "pai_coding";

    public static void main(String[] args) {
        try (Connection conn = DriverManager.getConnection(URL, USER, PASSWORD);
             Statement stmt = conn.createStatement()) {

            if (!databaseExists(conn, DATABASE_NAME)) {
                stmt.executeUpdate("CREATE DATABASE IF NOT EXISTS " + DATABASE_NAME);
                System.out.println("数据库创建成功");
            } else {
                System.out.println("数据库已经存在");
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    private static boolean databaseExists(Connection conn, String dbName) throws SQLException {
        ResultSet resultSet = conn.getMetaData().getCatalogs();

        while (resultSet.next()) {
            if (dbName.equals(resultSet.getString(1))) {
                return true;
            }
        }

        return false;
    }
}

这里简单解释一下大家可能比较陌生的代码:

先说 main 方法:

①、DriverManager.getConnection(URL, USER, PASSWORD):通过 JDBC 建立到 MySQL 服务器的连接。

②、conn.createStatement():创建一个 Statement 对象来执行 SQL 命令。

③、stmt.executeUpdate("CREATE DATABASE IF NOT EXISTS " + DATABASE_NAME):执行 SQL 命令,创建数据库。这就和我们本篇的主题串起来了,哈哈😆。

再说 databaseExists 方法:

①、使用 Connection 对象的 getMetaData() 方法可以获取数据库的元数据。这个元数据包含了服务器上所有数据库的信息。

②、getCatalogs() 方法可以获取服务器上所有数据库的列表,返回的 ResultSet 对象包含了服务器上每个数据库的名称。

③、resultSet.getString(1) 方法可以获取当前行第一列的值,也就是数据库的名称。

Spring Boot

Spring Boot 项目的话,就比较省事了,不用去下载驱动,直接在 pom.xml 文件中添加 MySQL 的驱动依赖就可以了。

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.19</version>
</dependency>

接着在 application.yml 配置文件中,设置数据库的基本连接信息。

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/?useSSL=false&serverTimezone=UTC
    username: root
    password: 123456

然后在 Spring Boot 的测试类中进行数据库创建操作。

@Slf4j
@SpringBootTest(classes = QuickForumApplication.class)
@RunWith(SpringJUnit4ClassRunner.class)
public class DatabaseCreationTest {

    @Autowired
    private DataSource dataSource;

    @Autowired
    private JdbcTemplate jdbcTemplate;

    @Test
    public void createDatabaseTest() throws SQLException {
        String dbName = "pai_coding";
        if (!databaseExists(dbName)) {
            jdbcTemplate.execute("CREATE DATABASE IF NOT EXISTS " + dbName);
            System.out.println("创建成功");
        } else {
            System.out.println("已存在");
        }
    }

    private boolean databaseExists(String dbName) throws SQLException {
        try (Connection connection = dataSource.getConnection();
             Statement statement = connection.createStatement()) {
            ResultSet set = statement.executeQuery("select schema_name from information_schema.schemata where schema_name = '" + dbName + "'");
            return set.next();
        }
    }
}

这里也简单解释一下大家可能比较陌生的代码:

①、@Slf4jLombok 库open in new window提供的注解,用于自动创建日志对象(比如 Logger)。

②、@SpringBootTest(classes = QuickForumApplication.class):表示这是一个 Spring Boot 的集成测试类,它会加载技术派项目open in new window QuickForumApplication 类指定的 Spring Boot 应用程序上下文。

③、@RunWith(SpringJUnit4ClassRunner.class):使用 JUnit4 来支持 Spring 上下文测试。

④、@Autowired:自动注入 DataSource 和 JdbcTemplate 对象。

大家可以尝试下,看看能不能成功。

关于 Spring Boot 的更多知识,可以参考:Spring Boot 进阶之路open in new window

源码:DatabaseCreationTestopen in new window

小结

本篇我们主要讲解了 MySQL 数据库的基本操作,包括创建数据库、切换数据库、删除数据库。

并结合技术派实战项目来讲解了技术派是如何自动创建数据库的。以及如何通过 Java 原生代码和 Spring Boot 项目来创建数据库。

希望大家动动手,练习一下,实战和理论真正的结合起来,冲鸭😁。


GitHub 上标星 10000+ 的开源知识库《二哥的 Java 进阶之路open in new window》第一版 PDF 终于来了!包括Java基础语法、数组&字符串、OOP、集合框架、Java IO、异常处理、Java 新特性、网络编程、NIO、并发编程、JVM等等,共计 32 万余字,500+张手绘图,可以说是通俗易懂、风趣幽默……详情戳:太赞了,GitHub 上标星 10000+ 的 Java 教程open in new window

微信搜 沉默王二 或扫描下方二维码关注二哥的原创公众号沉默王二,回复 222 即可免费领取。