原创 解决问题:windows中,通过Django ORM创建数据表,MySQL中文乱码

2019-7-6 10:52 3604 21 21 分类: 软件与OS 文集: MySQL
问题:
windows中,通过Django ORM创建数据表,MySQL中文乱码
问题原因:
字符集不匹配。
原因详情:
windows中,默认字符集为gbk。
MySQL数据库中,默认字符集为latin1。
python代码中,默认字符集为utf8。
解决方法:
思路:
先将mysql中的当前默认字符集改为utf8后,再执行Django ORM操作。
为兼容表情包等富文本,将字符集改为utf8mb4。
操作步骤:
1.mysql操作
1.1登录mysq
在windows中,cmd进控制台。
输入命令:mysql -u root -p 输入mysql密码
1.2在mysql中,操作:
1) 查看mysql当前字符集编码 show variables like '%char%';
2)修改mysql当前默认字符集 set 变量名 = 字符集名;
set character_set_client=utf8mb4;
set character_set_connection=utf8mb4;
set character_set_database=utf8mb4;
set character_set_results=utf8mb4;
set character_set_server=utf8mb4;
执行set character_set_system=utf8mb4;时,会报错: ERROR 1238 (HY000): Variable 'character_set_system' is a read only variable不必紧张,不用修改此变量的字符集,继续操作,因它不会影响最终效果。
3)查看mysql修改后的字符集编码 show variables like '%char%';
2.Django ORM操作
2.1切换到Django项目所在目录
2.2执行数据库迁移
python manage.py makemigrations
python manage.py migrate
2.3运行Django服务器
python manage.py runserver
3.验证
在浏览器中打开测试url,添加含的中文字符的记录。
没有报错,表示此问题已解决。
方法利弊:
此方法为临时解决方法。
优点:操作简单,不修改MySQL数据库的配置文件,不停MySQL数据库,不修改原有数据库数据。
缺点:MySQL数据库重启后,MySQL默认字符集恢复为配置文件中配置的字符集。你需在更新数据库结构前,重复上述改MySQL默认字符集编码的操作。
风险:前提:数据库中原没有其他编码的数据,否则原数据如为Latin1,有可能无法正常显示,大概率是能正常显示的。这个,你可自行测试看看结果。
如果不幸这样,你也不用着急。在MySQL中,show create table 表名;查看原数据表的字符集。将MySQL默认字符集改为此字符集,就能解决这个问题。但中文这个就暂时解决不了了。
说明:为什么不直接改MySQL数据库的配置文件my.ini,因为我测试时遇到改了以下内容,MySQL服务就启动不起来的情况。如果你有好的解决方法,欢迎留言告诉我。
[mysqld]
character-set-server=utf8
default-character-set=utf8 #或

作者: niceday, 来源:面包板社区

链接: https://mbb.eet-china.com/blog/uid-me-1668165.html

版权声明:本文为博主原创,未经本人允许,禁止转载!

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
21
关闭 站长推荐上一条 /3 下一条