mysqldump使用cmd窗口和powersell窗口导出sql中文乱码的问题

项目场景

我在使用Mariadb数据库更新数据的时候,由于数据库的表格中含有中文,在使用mysqldump导出sql语句的时候,中文显示乱码,如下图所示:

环境描述

  • 系统:windows10
  • 数据库: Mariadb -10.6.16-winx64

解决办法

首先查看一下我的数据库test的编码,连接数据库后输入

shell 复制代码
# 我的用户名为 root 端口号为13306 密码为mariadb123
mysql -uroot -P13306 -pmariadb123

连接上数据库后,然后输入:

sql 复制代码
#查看所有数据库
show databases;
#切换/打开test数据库 如果不切换数据库直接查询编码的结果会有所不同 如下图1(未切换数据库) 图2(切换数据库test)
use test;
#查看数据库的编码
show variables like "character%";

查询结果如下图所示:


其中:

  • character_set_client: 设置客户端使用的字符集。
  • character_set_connection: 连接数据库的字符集设置类型,如果程序没有指明连接数据库使用的字符集类型则按照服务器端默认的字符集设置。
  • character_set_database: 设置数据库服务器中某个库的字符集。
  • character_set_filesystem: 设置文件系统的字符集。
  • character_set_results: 设置服务端返回给客户端结果显示使用的字符集。
  • character_set_server: 设置服务器安装时指定的默认字符集。
  • character_set_system: 设置数据库系统使用的字符集。

原文关于mysqldump的使用说明点击此处学习

意思是:

在 Windows 上使用 PowerShell 创建的转储,其中包含输出 重定向会创建一个采用 UTF-16 编码的文件:

mysqldump [options] > dump.sql
但是,不允许将 UTF-16 作为连接字符集 (请参见不允许的客户端字符集), 因此无法正确加载转储文件。解决方法 此问题,请使用选项 ,这将以 ASCII 格式创建输出:--result-file
mysqldump [options] --result-file=dump.sql

使用cmd窗口和powershell窗口连接Mariadb数据库,导出sql的代码如下所示:

shell 复制代码
#cmd窗口  数据库为test 需要导出的表格为export5 
#导出的文件位置为 C:\Users\XXX\Desktop\temp\export5.sql
#此处导出数据用的符号位 >
mysqldump -uroot -P13306 -p --default-character-set UTF8 --hex-blob test export5 > C:\Users\XXX\Desktop\temp\export5.sql


#shell窗口  数据库为test 需要导出的表格为export5
#导出的文件位置为 C:\Users\XXX\Desktop\temp\export5.sql
#--hex-blob, 是为了把BINARY, VARBINARY, BLOB, BIT等类型导出为十六进制,这些类型比较容易乱码。
#--no-create-info,是不要编写重新创建每个转储表的 CREATE TABLE 语句,可根据需求删除。
#此处导出数据用的是 --result-file=
mysqldump -uroot -P13306 -pmariadb123 --default-character-set=utf8 --hex-blob --no-create-info test export5 --result-file=C:\Users\XXX\Desktop\temp\export5.sql

最终结果:

问题解决。


小结

想要深入学习的点击此处学习MySQL的说明文档

相关推荐
zuoerjinshu4 小时前
sql实战解析-sum()over(partition by xx order by xx)
数据库·sql
NocoBase5 小时前
【2.0 教程】第 1 章:认识 NocoBase ,5 分钟跑起来
数据库·人工智能·开源·github·无代码
Hoshino.416 小时前
基于Linux中的数据库操作——下载与安装(1)
linux·运维·数据库
Oueii8 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python
未来龙皇小蓝8 小时前
【MySQL-索引调优】11:Group by相关概念
数据库·mysql·性能优化
2401_831824968 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python
njidf9 小时前
Python日志记录(Logging)最佳实践
jvm·数据库·python
twc8299 小时前
大模型生成 QA Pairs 提升 RAG 应用测试效率的实践
服务器·数据库·人工智能·windows·rag·大模型测试
@我漫长的孤独流浪9 小时前
Python编程核心知识点速览
开发语言·数据库·python
2401_851272999 小时前
实战:用Python分析某电商销售数据
jvm·数据库·python