Unknown database engine MySQL

create DATABASE mysql_app_db ENGINE = MySQL('172.17.0.1:13306', 'dbname', 'user', 'password');

CREATE DATABASE mysql_app_db
ENGINE = MySQL('172.17.0.1:13306', 'dbname', 'user', 'password')

Received exception from server (version 19.8.3):
Code: 336. DB::Exception: Received from localhost:9000, 127.0.0.1. DB::Exception: Unknown database engine
ENGINE = MySQL('172.17.0.1:13306', 'dbname', 'user', 'password'). 

0 rows in set. Elapsed: 0.133 sec. 

需要使用Clickhouse读取Mysql数据库数据,在Clickhouse中建立mysql引擎的数据mysql_db_app指向需要读取的MySQL数据库。不想却报了错:

Unknown databse engine ——用俺河南话说就是这货还不知道mysql引擎是弄啥嘞啊。从错误信息中注意到当前使用的Clickhouse版本是19.x,可能是当前版本还没有添加MySQL引擎数据库功能,抱着试一试的态度准备升级个20.x,毕竟使用docker安装这些软件那是得劲类很:

--重tag现有镜像

tianlang@tianlang-VirtualBox:~$ docker images |grep clickhouse
yandex/clickhouse-server    latest              8e4e71f24366        19 months ago       484MB
yandex/clickhouse-client    latest              4d1c9c06f912        19 months ago       459MB

-- -- 把现有镜像重tag
tianlang@tianlang-VirtualBox:~$ docker tag yandex/clickhouse-server:latest yandex/clickhouse-server:19.8.3.8
tianlang@tianlang-VirtualBox:~$ docker tag yandex/clickhouse-client:latest yandex/clickhouse-client:19.8.3.8
tianlang@tianlang-VirtualBox:~$ docker images |grep clickhouse
yandex/clickhouse-server    19.8.3.8            8e4e71f24366        19 months ago       484MB
yandex/clickhouse-server    latest              8e4e71f24366        19 months ago       484MB
yandex/clickhouse-client    19.8.3.8            4d1c9c06f912        19 months ago       459MB
yandex/clickhouse-client    latest              4d1c9c06f912        19 months ago       459MB

-- -- 删除tag为latest的镜像,这样才好重新拉取
tianlang@tianlang-VirtualBox:~$ docker rmi yandex/clickhouse-server:latest 
Untagged: yandex/clickhouse-server:latest
tianlang@tianlang-VirtualBox:~$ docker images |grep clickhouse
yandex/clickhouse-server    19.8.3.8            8e4e71f24366        19 months ago       484MB
yandex/clickhouse-client    19.8.3.8            4d1c9c06f912        19 months ago       459MB
yandex/clickhouse-client    latest              4d1c9c06f912        19 months ago       459MB
tianlang@tianlang-VirtualBox:~$ docker rmi yandex/clickhouse-client:latest 
Untagged: yandex/clickhouse-client:latest

-- 重新拉取最新的镜像
tianlang@tianlang-VirtualBox:~$ docker pull yandex/clickhouse-server:latest
latest: Pulling from yandex/clickhouse-server
da7391352a9b: Pull complete 
14428a6d4bcd: Pull complete 
2c2d948710f2: Pull complete 
076cd2c6a81e: Pull complete 
201ea6cda8c8: Pull complete 
0d7b4e598027: Pull complete 
0d86a58e3639: Pull complete 
3b78a4fd0f92: Pull complete 
86d65487f611: Pull complete 
dc82dea7d6fe: Pull complete 
Digest: sha256:8f669dafd35eb527210cc77973ed927734dff2c2cafd345823c8c99769124fd1
Status: Downloaded newer image for yandex/clickhouse-server:latest
docker.io/yandex/clickhouse-server:latest
tianlang@tianlang-VirtualBox:~$ docker pull yandex/clickhouse-client:latest
latest: Pulling from yandex/clickhouse-client
f22ccc0b8772: Pull complete 
3cf8fb62ba5f: Pull complete 
e80c964ece6a: Pull complete 
6f064a173914: Pull complete 
37a06aaf9ee5: Pull complete 
Digest: sha256:504e18bed5162a20bbff6071ca1b7c7baca1380d2e2755e4d6bf4bac7e534531
Status: Downloaded newer image for yandex/clickhouse-client:latest
docker.io/yandex/clickhouse-client:latest
tianlang@tianlang-VirtualBox:~$ docker images |grep clickhouse
yandex/clickhouse-server    latest              57e938a0aaae        3 weeks ago         819MB
yandex/clickhouse-client    latest              e677d3a4035c        3 weeks ago         492MB
yandex/clickhouse-server    19.8.3.8            8e4e71f24366        19 months ago       484MB
yandex/clickhouse-client    19.8.3.8            4d1c9c06f912        19 months ago       459MB

使用拉取好的最新docker镜像启动一个Clickhouses并尝试创建MySQL引擎的数据库.

 

还真没有再报错了。新版本就是牛!感谢Docker让俺这么快就用上了新版本.

不知道19版本的Clickhouse要使用MySQL引擎是不是需要些额外的操作.

 

 

mysql> -- 创建学生管理数据库 mysql> CREATE DATABASE IF NOT EXISTS student_management -> DEFAULT CHARACTER SET utf8mb4 -> COLLATE utf8mb4_0900_ai_ci; ERROR 1273 (HY000): Unknown collation: 'utf8mb4_0900_ai_ci' mysql> mysql> USE student_management; ERROR 1049 (42000): Unknown database 'student_management' mysql> mysql> -- 学生表 mysql> CREATE TABLE students ( -> student_id INT AUTO_INCREMENT PRIMARY KEY, -> name VARCHAR(50) NOT NULL, -> gender ENUM('男','女') DEFAULT '男', -> birthdate DATE, -> contact_phone VARCHAR(15) UNIQUE -> ) ENGINE=InnoDB; ERROR 1046 (3D000): No database selected mysql> mysql> -- 课程表 mysql> CREATE TABLE courses ( -> course_id INT AUTO_INCREMENT PRIMARY KEY, -> course_name VARCHAR(50) NOT NULL, -> credit TINYINT UNSIGNED DEFAULT 1 -> ); ERROR 1046 (3D000): No database selected mysql> mysql> -- 成绩表 mysql> CREATE TABLE scores ( -> score_id INT AUTO_INCREMENT PRIMARY KEY, -> student_id INT, -> course_id INT, -> score DECIMAL(5,2) CHECK (score BETWEEN 0 AND 100), -> exam_date DATE, -> FOREIGN KEY (student_id) REFERENCES students(student_id), -> FOREIGN KEY (course_id) REFERENCES courses(course_id) -> ); ERROR 1046 (3D000): No database selected mysql> mysql> -- 插入示例数据 mysql> INSERT INTO students (name, gender, birthdate, contact_phone) VALUES -> ('张三', '男', '2003-05-15', '13800138001'), -> ('李四', '女', '2002-11-23', '13900139002'); ERROR 1046 (3D000): No database selected mysql> mysql> INSERT INTO courses (course_name, credit) VALUES -> ('高等数学', 4), -> ('大学物理', 3), -> ('数据库原理', 2); ERROR 1046 (3D000): No database selected mysql> mysql> INSERT INTO scores (student_id, course_id, score, exam_date) VALUES -> (1, 1, 85.5, '2023-06-10'), -> (1, 3, 92.0, '2023-06-12'), -> (2, 2, 78.5, '2023-06-11'); ERROR 1046 (3D000): No database selected mysql> mysql> -- 查询示例 mysql> -- 查询学生基本信息 mysql> SELECT * FROM st
04-01
<think>嗯,用户遇到了两个MySQL的错误:'Unknown collation: utf8mb4_0900_ai_ci'和'No database selected'。我需要仔细分析这两个问题的原因,然后给出解决方法。 首先,关于'Unknown collation: utf8mb4_0900_ai_ci'这个错误。我记得utf8mb4是MySQL支持的一种字符集,而0900_ai_ci可能和版本有关。可能用户使用的MySQL版本比较旧,而utf8mb4_0900_ai_ci是在MySQL 8.0中引入的排序规则。所以,如果用户的环境是低于8.0的版本,比如5.7或者更早,就会不认识这个排序规则,导致报错。这时候需要将排序规则改为旧版本支持的,比如utf8mb4_general_ci,或者升级MySQL到8.0以上。 然后,关于'No database selected'错误。这个通常发生在执行操作时没有选择数据库。比如在创建表或者插入数据之前没有使用USE语句指定数据库,或者在导入SQL文件时没有指定数据库。根据引用[2]提到的,用户可能在导入时没有勾选创建数据库的选项,或者没有在SQL文件中包含CREATE DATABASE语句。解决方法包括在操作前用USE命令指定数据库,或者在导入时确保数据库存在并正确选择。 接下来,我需要确认用户的情况。比如,用户可能是在迁移数据库时从高版本导出的SQL文件,然后在低版本导入,导致字符集和排序规则不兼容。或者用户手动创建数据库时指定了不支持的排序规则。对于'No database selected',可能是在执行CREATE TABLE语句前没有选择数据库,或者在导入时没有指定数据库。 解决方法方面,对于Unknown collation,有两个主要途径:一是修改字符集和排序规则为兼容旧版本的,如将utf8mb4_0900_ai_ci替换为utf8mb4_general_ci;二是升级MySQL到8.0以上版本。用户需要根据自己的实际情况选择。如果是导入的SQL文件,可以批量替换排序规则部分。如果是手动创建,则需要在CREATE DATABASE或CREATE TABLE时明确指定支持的排序规则。 对于No database selected,需要确保在执行操作前已经选择数据库。可以通过USE命令,或者在连接时指定数据库,或者在SQL文件中添加CREATE DATABASE和使用它的语句。另外,在导入时使用选项如-D来指定数据库,或者在图形工具中勾选创建Schema的选项,如引用[2]提到的。 还需要提醒用户注意,修改字段或表结构时的语法是否正确,如引用[3]中的ALTER TABLE语句示例,确保语法正确,避免其他错误。 最后,生成相关问题,帮助用户进一步解决可能遇到的问题,比如如何检查数据库默认字符集,如何修改现有表的排序规则,或者导入数据时的其他注意事项。</think>### 解决 MySQL 中 'Unknown collation: utf8mb4_0900_ai_ci' 和 'No database selected' 错误的方法 #### 一、'Unknown collation: utf8mb4_0900_ai_ci' 错误 **原因分析** 此错误通常由以下原因导致: 1. **MySQL 版本过低**:`utf8mb4_0900_ai_ci` 是 MySQL 8.0 引入的排序规则(Collation),如果使用低于 8.0 的版本(如 5.7 或更早),系统无法识别该规则[^1]。 2. **手动指定了不兼容的排序规则**:在创建数据库或表时,显式指定了旧版本不支持的排序规则。 **解决方法** 1. **升级 MySQL 到 8.0 或更高版本**(推荐): 通过升级可完全兼容 `utf8mb4_0900_ai_ci`,同时支持更多新特性。 2. **修改排序规则为旧版本支持的格式**: 创建数据库或表时,将排序规则改为 `utf8mb4_general_ci`。例如: ```sql CREATE DATABASE mydb CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; ``` 3. **批量替换 SQL 文件中的排序规则**: 如果是导入 SQL 文件导致的错误,可将文件中所有 `utf8mb4_0900_ai_ci` 替换为 `utf8mb4_general_ci`。 --- #### 二、'No database selected' 错误 **原因分析** 此错误表示操作未指定目标数据库,常见于以下场景: 1. 执行 `CREATE TABLE` 或 `INSERT` 前未通过 `USE` 命令选择数据库。 2. 导入 SQL 文件时未指定目标数据库,且文件中未包含 `CREATE DATABASE` 语句[^2]。 **解决方法** 1. **显式选择数据库**: 在操作前使用 `USE` 命令: ```sql USE mydb; CREATE TABLE mytable (...); ``` 2. **在连接时指定数据库**: 通过命令行参数 `-D` 指定数据库: ```bash mysql -u root -p -D mydb < dump.sql ``` 3. **在 SQL 文件中添加数据库创建语句**: 确保 SQL 文件开头包含: ```sql CREATE DATABASE IF NOT EXISTS mydb; USE mydb; ``` 4. **勾选图形工具的 "Create Schema" 选项**: 如引用[2]所述,在 Navicat 等工具导入时需勾选此选项以自动创建库。 --- #### 三、操作验证示例 1. **检查当前数据库编码和排序规则**: ```sql SHOW VARIABLES LIKE 'character_set_database'; SHOW VARIABLES LIKE 'collation_database'; ``` 结果示例(需确保与预期一致): ``` +------------------------+---------+ | Variable_name | Value | +------------------------+---------+ | character_set_database | utf8mb4 | +------------------------+---------+ ``` 2. **修改现有表的排序规则**: 若需调整已有表,可使用 `ALTER TABLE`(注意字段类型匹配): ```sql ALTER TABLE mytable CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

CoderFusionZhu

不要打赏太多哦!我喝速溶就行

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

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

打赏作者

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

抵扣说明:

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

余额充值