解决django 向mysql中写入中文字符出错的问题


Posted in Python onMay 18, 2020

之前使用django+mysql建立的一个站点,发现向数据库中写入中文字符时总会报错,尝试了修改settings文件和更改数据表的字符集后仍不起作用。最后发现,在更改mysql的字符集后,需要重建数据库,才能起作用。

这里完整记录一下解决方案

首先更改mysql的字符集

ubuntu下找到/etc/mysql/my.cnf   在最后添加

[mysqld]
character-set-server=utf8
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

用mysql -h localhost -u root -p 命令进入mysql 命令行

然后使用 show variables like 'character_set%'; 查看字符集设置,看到 client server database 为utf8即为成功

但是我的django依然报错,只能重建数据库,如果数据库文件不多,重建数据库的工作量其实非常小

首先建立新的数据库,此时默认编码格式就是utf8,已经支持中文、

然后修改settings.py中的database项的name为新的数据库名

最后执行数据库迁移即可,在包含manage.py文件夹目录下

python manage.py makemigrations

python manage.py migrate

即可创建用户表和modle中自定的表格,表结构与原来相同,将数据复制到新表即可

补充知识:解决django字符集 输入汉字之后mysql数据库报错的问题【慎用】

解决思路:

启动mysql数据库 net start mysql

之后: mysql -u root -p

查看数据库字符集 show variables like ‘character%';

发现 character-set-server 和 character_set_database 的值为latin1

解决方案:

编辑查看MySQL文件夹下的my.ini 配置文件

在[mysqld]下添加 character-set-server=utf8

systemctl restart mysql 重启 MySQL Server,再此查看字符集变量,发现已经是utf8

drop database 【已经添加的数据库】 并 create database 【新数据库】

问题解决!

此方法简单粗暴,慎用!数据库里面的文件还要重写,比较麻烦,不过可以在创建数据库之后,添加一条数据,利用自定义的django图形化界面,再添加数据也是可以的。

以上这篇解决django 向mysql中写入中文字符出错的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python自动化工具日志查询分析脚本代码实现
Nov 26 Python
python绘制简单折线图代码示例
Dec 19 Python
Python基于whois模块简单识别网站域名及所有者的方法
Apr 23 Python
完美解决Pycharm无法导入包的问题 Unresolved reference
May 18 Python
selenium处理元素定位点击无效问题
Jun 12 Python
PyCharm+Qt Designer+PyUIC安装配置教程详解
Jun 13 Python
Python 二叉树的层序建立与三种遍历实现详解
Jul 29 Python
Pycharm远程调试原理及具体配置详解
Aug 08 Python
Python如何基于smtplib发不同格式的邮件
Dec 30 Python
Python多线程正确用法实例解析
May 30 Python
改变 Python 中线程执行顺序的方法
Sep 24 Python
Python 带星号(* 或 **)的函数参数详解
Feb 23 Python
Anaconda3中的Jupyter notebook添加目录插件的实现
May 18 #Python
python实现人像动漫化的示例代码
May 17 #Python
django日志默认打印request请求信息的方法示例
May 17 #Python
使用pyecharts1.7进行简单的可视化大全
May 17 #Python
python使用for...else跳出双层嵌套循环的方法实例
May 17 #Python
VSCode配合pipenv搞定虚拟环境的实现方法
May 17 #Python
Python Pandas 对列/行进行选择,增加,删除操作
May 17 #Python
You might like
用PHP制作静态网站的模板框架
2006/10/09 PHP
PHP代码优化技巧小结
2015/09/29 PHP
PHP链表操作简单示例
2016/10/15 PHP
PHP对象相关知识总结
2017/04/09 PHP
PHP异步进程助手async-helper
2018/02/05 PHP
PHP简单实现图片格式转换(jpg转png,gif转png等)
2019/10/30 PHP
PHP中echo与print区别点整理
2021/03/09 PHP
用YUI做了个标签浏览效果
2007/02/20 Javascript
解读IE和firefox下JScript和HREF的执行顺序
2008/01/12 Javascript
Jquery+asp.net后台数据传到前台js进行解析的方法
2014/05/11 Javascript
JS定时器实现数值从0到10来回变化
2016/12/09 Javascript
Bootstrap禁用响应式布局的实现方法
2017/03/09 Javascript
JavaScript之filter_动力节点Java学院整理
2017/06/28 Javascript
JS实现鼠标拖拽盒子移动及右键点击盒子消失效果示例
2019/01/29 Javascript
vue 实现 rem 布局或vw 布局的方法
2019/11/13 Javascript
[01:10:03]OG vs EG 2018国际邀请赛淘汰赛BO3 第三场 8.23
2018/08/24 DOTA
实践Python的爬虫框架Scrapy来抓取豆瓣电影TOP250
2016/01/20 Python
使用Python对SQLite数据库操作
2017/04/06 Python
Python3 获取一大段文本之间两个关键字之间的内容方法
2018/10/11 Python
Pythony运维入门之Socket网络编程详解
2019/04/15 Python
Django 开发环境与生产环境的区分详解
2019/07/26 Python
使用python批量修改文件名的方法(视频合并时)
2020/03/24 Python
详解Django-channels 实现WebSocket实例
2019/08/22 Python
面向对象学习之pygame坦克大战
2019/09/11 Python
Python Pandas数据分析工具用法实例
2020/11/05 Python
世界上最受欢迎的花店:1-800-Flowers.com
2020/06/01 全球购物
Tea Collection官网:一家位于旧金山的童装公司
2020/08/07 全球购物
营销与策划专业毕业生求职信
2013/11/01 职场文书
中国梦主题教育活动总结
2014/05/05 职场文书
股份合作协议书
2014/09/10 职场文书
大学生就业协议书范本(适用于公司企业)
2014/10/07 职场文书
学生检讨书如何写
2014/10/30 职场文书
2014年校长工作总结
2014/12/11 职场文书
2015年度企业工作总结
2015/05/21 职场文书
laravel ajax curd 搜索登录判断功能的实现
2021/04/17 PHP
Javascript的promise,async和await的区别详解
2022/03/24 Javascript