mysql 运行sql 编码_关于解决运行 sql 文件时, 找不到 MySQL 默认编码 utf8mb4 的问题...

关于解决运行 sql 文件时, 找不到 MySQL 默认编码 utf8mb4 的问题

本人小白一名, 最近碰到了一个问题, 在 navicat 导入 MySQL 文件时, 报出 MySQL 找不到 utf8mb4 编码的问题, 特此记录自己如何导入成功的.

我去百度查了自己的 MySQL 版本, 属于比较低的版本, 所以默认编码中没有 utf8mb4, 默认编码是 utf8, 学生嘛, 用不到那么高的版本, 基本低版本的就足够开发一些实训项目的了.

首先看到这个错误, 我的第一反应是修改这个 sql 文件的编码格式, 即将 utf8mb4->utf8, 以记事本的形式打开这个 sql 文件

ab7653affab982b574eb7acc55df2e04.gif

编辑 -> 替换 -> 将所有 utf8mb4 换成 utf8

然后进入 navicat, 重新运行 sql 文件, 结果 失败了, 出现了个代号为 1064 的错误, 然后我就想, 可不可以通过运行语句来实现呢?

打开 navicat, 点击查询, 然后新建查询

ab7653affab982b574eb7acc55df2e04.gif

然后再打开刚才替换过编码的 sql 文件, ctrl+A 全选, 然后 ctrl+C 复制, 将内容复制到新建查询里, 点击那个小三角图标, 运行语句, 最终结果 成功啦!

这类方式只适用在比较小的项目, 数据库没那么复杂的情况, 如果是大项目建议问其他大佬 hhhh

来源: http://www.bubuko.com/infodetail-3375268.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你可以使用下面的 SQL 语句来查所有表的字段编码不为 utf8mb4_General_ci 的表名: ``` SELECT TABLE_NAME FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = 'your_database_name' AND COLLATION_NAME != 'utf8mb4_general_ci'; ``` 请将 `your_database_name` 替换为你的数据库名称。这个语句将从 `information_schema.COLUMNS` 表中检索所有表的名称,并只返回编码不为 `utf8mb4_General_ci` 的表。 ### 回答2: 要查字段编码不为utf8mb4_general_ci的所有表名,可以使用以下步骤: 1. 连接到MySQL数据库。可以使用命令行工具如MySQL命令行客户端、phpMyAdmin或者其他图形界面工具来连接。 2. 运行以下SQL查询语句来获取所有表名及其字段编码: ```sql SELECT TABLE_NAME FROM information_schema.TABLES WHERE TABLE_COLLATION NOT LIKE '%utf8mb4_general_ci%' ``` 3. 执行查询语句后,将会返回一个结果集,其中包含所有字段编码不为utf8mb4_general_ci的表名。 4. 可以根据需要进一步处理查询结果,例如将结果导出为文本文件、将结果用于其他查询等。 这个查询语句使用了MySQL的information_schema.TABLES表,该表存储了关于数据库中的所有表的详细信息,包括表名、字段编码等。通过在WHERE子句中使用LIKE运算符,我们可以过滤出字段编码不为utf8mb4_general_ci的表名。 ### 回答3: 可以使用以下SQL语句来查询所有表名中字段编码不为utf8mb4_general_ci的表: ``` SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_COLLATION NOT LIKE 'utf8mb4_general_ci' ``` 以上语句使用了`INFORMATION_SCHEMA.TABLES` 视图来获取数据库中的所有表的信息,然后根据 `TABLE_COLLATION` 字段来判断表的编码是否符合要求。 `TABLE_COLLATION` 是表示表编码的字段,如果该字段的值不以 `utf8mb4_general_ci` 结尾,就代表该表的编码不是 `utf8mb4_general_ci`。 通过以上SQL查询语句,可以获取到所有字段编码不为 `utf8mb4_general_ci` 的表的表名。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值