使用Java生成MySQL数据库

Java 动态生成 MYsql 数据库

首先准备一个类,表示用于生成数据库等操作。

java 复制代码
/*
  TenantDatabaseDTO 用于传递租户数据库相关的信息。
 */
public class TenantDatabaseDTO {
    // 数据库名称
    private String tenantDatabase;
    // 数据库用户
    private String dbUser;
    // 数据库密码
    private String dbPass;
    // 管理员名称
    private String adminName;
    // 管理员密码
    private String adminPass;
    // 名称
    private String tenantName;
    // 数据库连接 URL
    private String url;
}

接下来我们开始连接数据库操作

我们首先创建数据库连接,Statement 是执行语句对象,用于执行 sql,Connection 是连接对象,可以通过 setAutoCommit 开启一个事务,也就是不会自动提交。

java 复制代码
// url
String url = "jdbc:mysql://" + host + ":" + port + "/";

// 数据库账户密码
String username = "root";
String password = "1234";

// 获取数据库连接
Connection conn = DriverManager.getConnection(url, username, password);
// 执行语句对象
Statement stmt = null;
// 关闭自动提交事务
conn.setAutoCommit(false);
// 创建执行语句对象
stmt = conn.createStatement();

创建数据库

我们拼接一个 SQL 用于创建一个数据库,通过执行语句的 execute 方法执行,由于我们开启了事务,最后提交事务才能完成创建。

java 复制代码
// 数据库名称
String database = "newDataBase";
// 创建库
String createDatabaseSQL = "CREATE DATABASE IF NOT EXISTS `" + database + "` DEFAULT CHARSET utf8mb4 COLLATE utf8mb4_general_ci;";
// 执行语句
stmt.execute(createDatabaseSQL);

这里由于我的业务需要给特定的数据库做专门的账户密码,所以下面需要再次执行两个,创建用户以及分配该数据的权限

java 复制代码
String databasePassword = "1234";
// 在这里要创建用户,并且存入相应用户和密码
String userSQL = "CREATE USER '" + database + "'@'localhost' IDENTIFIED BY '" + databasePassword + "';";
stmt.execute(userSQL);

//用户授权
String grantSQL = "GRANT select, insert, update, delete ON " + database + ".* TO '" + database + "'@'localhost'";
stmt.execute(grantSQL);

切换到刚刚的数据库

java 复制代码
// 切换到数据库
conn.setCatalog(tenantDatabase);

执行 SQL 脚本

ScriptRunner 类用于执行SQL脚本,需要和数据库连接 Connection 一起使用。因为需要传递连接器。

java 复制代码
ScriptRunner runner = new ScriptRunner(connection);
// 禁用一般日志
runner.setLogWriter(null);
// 禁用错误日志
runner.setErrorLogWriter(null);
// 从资源中获取 SQL 脚本的 Reader,位于 resources 目录下 init-sql-script下的文件,读取之后并执行。
Reader reader = Resources.getResourceAsReader("init-sql-script/erp-crm-tenant-sample.sql");
// 最后记得将事务提交
conn.commit();

小技巧

这样也可以更好的提交数据。

java 复制代码
SqlRunner sqlRunner = new SqlRunner(conn);
//插入部门
String insertSql = "INSERT INTO sys_dept VALUES (100, 0, '0', '" + tenantDatabaseDTO.getTenantName() + "', 0, '" + tenantDatabaseDTO.getTenantName() + "', '00000000000', 'admin@admin.com', '0', '0', 'admin', '" + DateUtils.getTime() + "', 'admin', '" + DateUtils.getTime() + "');";
sqlRunner.run(insertSql);
相关推荐
没有bug.的程序员7 分钟前
Spring Boot 与 Redis:缓存穿透/击穿/雪崩的终极攻防实战指南
java·spring boot·redis·缓存·缓存穿透·缓存击穿·缓存雪崩
草履虫建模7 分钟前
Java 基础到进阶|专栏导航:路线图 + 目录(持续更新)
java·开发语言·spring boot·spring cloud·maven·基础·进阶
Zhu_S W8 分钟前
Java多进程监控器技术实现详解
java·开发语言
Anastasiozzzz8 分钟前
LeetCodeHot100 347. 前 K 个高频元素
java·算法·面试·职场和发展
三水不滴9 分钟前
从原理、场景、解决方案深度分析Redis分布式Session
数据库·经验分享·redis·笔记·分布式·后端·性能优化
青芒.10 分钟前
macOS Java 多版本环境配置完全指南
java·开发语言·macos
Hx_Ma1611 分钟前
SpringMVC框架(上)
java·后端
幼稚园的山代王12 分钟前
JDK 11 LinkedHashMap 详解(底层原理+设计思想)
java·开发语言
不积硅步14 分钟前
jenkins安装jdk、maven、git
java·jenkins·maven
Cult Of15 分钟前
一个最小可扩展聊天室系统的设计与实现(Java + Swing + TCP)
java·开发语言·tcp/ip