linux终端查看数据库内容,乱码怎么解决

linux终端查看数据库内容,乱码怎么解决,第1张

如果是图形界面下的虚拟终端,设置(根据不同的 shell 修改不同的环境参数配置文件,如 bash 就修改 .bashrc 文件或 .bash_profile 文件)

1

export LANG=zh_CN.UTF-8

如果是远程登录(比如使用 ssh 登录),则根据你的客户端的环境进行设置,一个可能的方案是:

1

export LANG=zh_CN.GB18030

locale 看看你的当前是什么语言显示然后

1

vi /etc/sysconfig/<a href="https://www.baidu.com/s?wd=i18n&tn=44039180_cpr&fenlei=mv6quAkxTZn0IZRqIHckPjm4nH00T1YvPAfsPARvmHRdPHcdnjTL0ZwV5Hcvrjm3rH6sPfKWUMw85HfYnjn4nH6sgvPsT6KdThsqpZwYTjCEQLGCpyw9Uz4Bmy-bIi4WUvYETgN-TLwGUv3EPjnzPHD4nW0zPH6zPjbzrj6Y" target="_blank" class="baidu-highlight">i18n</a>

一般情况下linux服务器都是配置utf-8,不使用中文的。

解决方案无非就是把python的代码的开头编码用utf-8,打开数据库连接的时候也用charset='utf8',还搞什么sys.setdefaultencoding('gbk'),mysql的my.cnf配置文件里面配置为utf-8。等等之类的东西,无效,插入中文还是乱码,就是插到数据库里面,直接看数据库里的中文都是编码,或者是????什么的。

把问题简单化,mysql的默认编码为latin1,查找mysqldb的源码关键报错的地方是cursor.execute,这里要执行一下encode(charset),既然这里要encode,那就在外面先decode一下,果然什么都不改,在自己的调用函数里做decode。

sql

=

'insert

into

aa

values('测试')'

sql

=

sql.decode('latin1')

cursor.execute(sql)

这样就解决问题了,中文插入,中文显示,在终端命令行直接查看数据库也是中文。

试试,建表的时候不需要指定编码。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9608772.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-30
下一篇2023-04-30

发表评论

登录后才能评论

评论列表(0条)

    保存