Mysql 编码修改与 pymysql 编码参数说明

查看所有的编码

show variables like 'character%';

在配置文件 my.ini 中的 [mysqld] 章节下添加 character-set-server = utf8 改变 character_set_server 的编码,需要重启mysql服务生效。

character_set_database 的编码的配置不在配置文件中,使用

alter database databasename character set utf8 collate utf8_general_ci

命令来修改。


不修改 pymysql 的编码参数,在 pymysql.cursors.Cursor 对象进行 execute 查询语句中含有中文时,会报编码错误。

UnicodeEncodeError: 'latin-1' codec can't encode characters in position 32-34: ordinal not in range(256)

con = pymysql.connect(host = local, port = port, user = "root", passwd = "xxxxx", charset = "utf8", use_unicode = True)
cur = con.cursor()

带上关键字参数 chartset 指定为 utf8 即可。

  character_set_client     | gbk
  character_set_connection | gbk
  character_set_database   | utf8
 character_set_filesystem | binary
  character_set_results    | gbk
  character_set_server     | utf8
 character_set_system     | utf8
 character_sets_dir       | H:\Nonstop_db\update\mysql5.5.8\share\charsets\

可能造成乱码的是加黑的 5 种。

set names xxx 只不过是是将character_set_client ,character_set_connection,character_set_results 设置成 xxx 而已。

依次是客户端使用的编码,连接层的编码,查询结果的编码。




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值