MySQL建表导入sql时出现的异常

Unknown collation: 'utf8mb4_0900_ai_ci’的解决方法
往mysql(5.7版本)导入sql文件时,出现Unknown collation: 'utf8mb4_0900_ai_ci’错误。


出现这样的问题是原sql文件是mysql(8.0版本),高级往低级(5.6版本)导入时出现版本不兼容的情况。

解决:

把sql文件中的:


utf8mb4_0900_ai_ci替换为utf8_general_ci

utf8mb4替换为utf8

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flink CDC 并不直接提供获取 MySQL 建表语句的功能。Flink CDC 的主要作用是捕获数据库变更数据并传输到其他系统,而不是用于生成建表语句。 如果您需要获取 MySQL 数据库中已存在表的建表语句,可以通过其他方式来实现,例如使用 MySQL 的 `SHOW CREATE TABLE` 语句或通过数据库管理工具来导出建表语句。 以下是一种使用 `SHOW CREATE TABLE` 语句获取 MySQL 建表语句的方法: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; public class MySQLTableDDLExtractor { public static void main(String[] args) { // MySQL连接信息 String url = "jdbc:mysql://localhost:3306/your_database"; String username = "root"; String password = "your_password"; // 表名 String tableName = "your_table"; try (Connection conn = DriverManager.getConnection(url, username, password); Statement stmt = conn.createStatement()) { // 执行 SHOW CREATE TABLE 语句 String sql = "SHOW CREATE TABLE " + tableName; ResultSet rs = stmt.executeQuery(sql); if (rs.next()) { // 获取建表语句 String createTableStmt = rs.getString("Create Table"); System.out.println(createTableStmt); } } catch (SQLException e) { e.printStackTrace(); } } } ``` 请替换示例代码中的 `your_database`、`your_table`、`your_password` 为实际的数据库、表名和密码。 通过上述代码,您可以连接到指定的 MySQL 数据库,并执行 `SHOW CREATE TABLE` 语句来获取指定表的建表语句。您可以将建表语句输出到控制台或保存到文件中,以便后续使用。 请注意,上述代码中使用的是 JDBC 连接 MySQL 数据库,因此需要确保已经正确导入MySQL JDBC 驱动。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值