执行 show databases; 命令可以查看当前数据库的所有数据库。
注意在 MySQL 客户端执行 SQL 语句的时候要带上分号 ; 并按下 enter 键,不然 MySQL 会认为你还没有输入完,会换一行继续等待你输入。
OK,像上面截图中的 information_schema、mysql、performance_schema、sys 这些都是 MySQL 自带的数据库,剩余的 、codingmore、pai_coding 等都是我本地创建的数据库。
上面截图中的 pai_coding 就是技术派项目的数据库。
创建数据库
语法:create database 数据库名;
比如说我要创建一个名为 test 的数据库,就可以执行:
create database test;
如果提示 Query OK, 1 row affected (0.02 sec),说明数据库创建成功了。
再用 show databases; 命令查看一下,就可以看到 test 数据库了。
一个小技巧:MySQL 会记忆之前输入过的命令,使用键盘上的Tab上下箭头按键可以切换命令。
通常情况下,我们在创建数据库的时候会额外加上 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;
技术派是如何创建数据库的?
技术派创建数据库是自动完成的,当项目启动的时候就会自动创建数据库。
具体实现的方法我放在了我的项目专栏里面‘“自动初始化数据库”
这里我做一些简单的介绍,实现源码在 ForumDataSourceInitializer 这个类中。
注意看 autoInitDatabase 方法,这里是自动创建数据库的逻辑。
/**
* 数据库不存在时,尝试创建数据库
*/
private boolean autoInitDatabase() {
// 查询失败,可能是数据库不存在,尝试创建数据库之后再次测试
URI url = URI.create(SpringUtil.getConfig("spring.datasource.url").substring(5));
String uname = SpringUtil.getConfig("spring.datasource.username");
String pwd = SpringUtil.getConfig("spring.datasource.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 原生
Java 原生代码需要你先下载一个 MySQL 的 JDBC 驱动,驱动的作用是让 Java 程序能够和 MySQL 数据库进行交互。
MySQL :: Download Connector/J
将下载的 .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>
然后在 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();
}
}
}
这里也简单解释一下大家可能比较陌生的代码:
①、@Slf4j:Lombok库提供注解,用于自动创建日志对象(比如 Logger)。
②、@SpringBootTest(classes = QuickForumApplication.class):表示这是一个 Spring Boot 的集成测试类,它会加载技术派QuickForumApplication 类指定的 Spring Boot 应用程序上下文。
③、@RunWith(SpringJUnit4ClassRunner.class):使用 JUnit4 来支持 Spring 上下文测试。
④、@Autowired:自动注入 DataSource 和 JdbcTemplate 对象。
大家可以尝试下,看看能不能成功。