中文在mysql中乱码
时间: 2024-03-03 12:48:12 浏览: 75
中文乱码问题通常是因为数据库的字符集不支持中文字符,导致中文字符无法正常存储和读取。为解决该问题,可以尝试以下方法:
1. 确认数据库字符集是否为UTF-8,如果不是,则需要修改数据库字符集为UTF-8。
2. 在连接数据库时,设置连接字符集为UTF-8,例如:
```python
import pymysql
db = pymysql.connect(host='localhost', user='root', password='123456', database='test', charset='utf8')
```
3. 在创建表时,设置表的字符集为UTF-8,例如:
```sql
CREATE TABLE `students` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
`age` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
```
4. 在插入数据时,确保数据的编码方式为UTF-8,例如:
```python
import pymysql
db = pymysql.connect(host='localhost', user='root', password='123456', database='test', charset='utf8')
cursor = db.cursor()
sql = "INSERT INTO students(name, age) VALUES (%s, %s)"
cursor.execute(sql, ('张三', 20))
db.commit()
```
通过以上方法,可以有效解决中文乱码问题。
阅读全文