Ubuntu下MySQL输入中文报错

本文介绍了解决MySQL数据库中无法正确插入中文字符的问题。通过修改MySQL配置文件中的字符集设置为UTF8,并重启服务,确保所有相关字符集变量也设置为UTF8。对于已存在的数据库,可能还需要删除重建以确保兼容性。

insert的时候输入中文,出现错误输入不成功,ERROR SqlExceptionHelper:147 - Incorrect string value: '\xE6\xB2\xA1\xE5\x90\x83...' for column 'others' at row 1


1 修改mysql的配置文件

  ( /etc/mysql/conf.d/mysql.cnf

在[mysql]的下方加入如下语句:(注:这个文件下没有配置,只有【mysql】)


no-auto-rehash

default-character-set=utf8)  这一步可以不使用,为了将所有的字符都变成utf8 ,可以加上这一步,如果遇到修改后中文不能键入的问题,可以将这一步去掉只使用下面的一步试试.


/etc/mysql/mysql.conf.d/mysqld.cnf 
在[mysqld]下加入
socket = /var/run/mysqld/mysqld.sock
port = 3306
character-set-server=utf8 (这里是server,之前有的版本是set)
重启mysql: sudo /etc/init.d/mysql restart
2.查看字符集

mysql> show variables like '%char%';
+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | utf8                       |
| character_set_connection | utf8                       |
| character_set_database   | utf8                       |
| character_set_filesystem | binary                     |
| character_set_results    | utf8                       |
| character_set_server     | utf8                       |
| character_set_system     | utf8                       |
| character_sets_dir       | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.00 sec)


在更改之前的数据库依旧不能录入中文,可以删除重新创建

就可以啦,,个人使用成功

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值