解决django 向mysql中写入中文字符出错的问题
作者:安~然 发布时间:2024-01-23 20:39:00
之前使用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图形化界面,再添加数据也是可以的。
来源:https://blog.csdn.net/zpy1998zpy/article/details/80201646
猜你喜欢
- 一、前言基于Mediapipe+Opencv实现手势检测,想实现一下姿态识别的时候,感觉手势识别也蛮重要的就过来顺便实现一下。下面是一些国内
- python 定时器默认定时器只执行一次,第一个参数单位S,几秒后执行import threadingdef fun_timer(): pr
- 利用ResNet18进行手写数字识别先写resnet18.py代码如下:import torchfrom torch import nnfr
- 如下所示://定义编码 header( 'Content-Type:text/html;charset=utf-8
- 下面这个函数使用FSO对象来判断服务器上的某个文件是否存在:<%Private Function Dir(byVa
- 一个是没有对输入的数据进行过滤(过滤输入),还有一个是没有对发送到数据库的数据进行转义(转义输出)。这两个重要的步骤缺一不可,需要同时加以特
- 感觉上MySQL的字符串函数截取字符,比用程序截取(如PHP或JAVA)来得强大,所以在这里做一个记录,希望对大家有用。 函数: 1、从左开
- 操作命令:show binlog events in 'mysql-bin.000016' limit 10;reset m
- 先利用pip安装pymssql库pip install pymssql具体连接、测试代码:# server默认为127.0.0.1,如果打开
- c shell perl php下的日期时间转换: 秒数与人类可读日期 scalar localtime 与 seconds since `
- 问题:变量名是否合法: 1.变量名可以由字母
- 上下文管理器和with块,具体内容如下上下文管理器对象存在的目的是管理 with 语句,就像迭代器的存在是为了管理 for 语句一样。wit
- 1.核心代码使用py2neo连接neo4j的方法:from py2neo import Graphgraph = Graph("h
- 本文实例为大家分享了Python/C++实现字符串逆序的具体代码,供大家参考,具体内容如下题目描述:将字符串逆序输出Python实现一:借助
- 一、简介pandas中的ExcelFile()和ExcelWriter(),是pandas中对excel表格文件进行读写相关操作非常方便快捷
- a {}{ background:url(images/normal.gif); } a:ho
- PHP生成桌面快捷方式就是这么的简单,大家生成的时候改下你要生成的网站即可。dianji.html代码:<a href="a
- 一直用pycharm写代码一直用anaconda管理python环境但是今天我居然发现我不会更改pycharm当前的运行环境到我新建的ana
- #squeeze 函数:从数组的形状中删除单维度条目,即把shape中为1的维度去掉#unsqueeze() 是squeeze()的反向操作
- 偶然在Google发现了他们的用户体验设计原则,因此翻译作一下记录。1.以人为本 —他们的生活、他们的工作和他们的梦想2.珍惜每一毫秒的时间