你报得那个unknown character set “utf” 表示你设置编码出问题了啊;
为雄县等地区用户提供了全套网页设计制作服务,及雄县网站建设行业解决方案。主营业务为网站建设、成都网站建设、雄县网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
你先登陆数据库:
mysql -uroot -p******
show varaibles like '%charater%';
把服务端或客户端 结果集等这些编码都重新设置一下:
set character_set+client="utf8"; #向这样 其他都要设置成utf8;
或者第二个方案:
直接修改配置文件my.ini。找到你的配置文件 。我截图的时我的配置文件位置;
首先你要保证你的mysql编码,和mysqlclient编码 都是utf8
在你的
my.cnf
里面就可以设置的。
默认的mysql编码居然是瑞典码,很是蹩脚。
这里指的中文数据是用中文命名数据表名和字段名吗,我建议你不要这么做,使用拼音或首字母的方式来命名,数据表后边写好注释是最好的选择。
使用中文命名数据表名和字段,实际使用中频繁会频繁切换输入法来查询,会很繁琐,其次,中文在编辑器和页面中存在编码的问题,会导致程序报错,再一个,别人拿到你的程序文件,根据数表名可以直接猜到你的数据表的用途,这也是不安全的。
A. 字符编码:
使用命令行方式登陆到MySQL服务器, 建立一个数据库,数据库编码设为UTF-8。此时,如果直接在命令行窗口使用insert语句插入中文,就遇到类似 ERROR 1406 (22001): Data too long for column 'name' at row 1 错误。乍一看,是字段长度引起的问题,但是实际是字符编码的问题。可是尝试以下解决方法:
1、在Linux中,使用终端方式登陆MySQL服务器,运行以下命令:
set names utf8;
该命令将终端的字符编码设为了UTF-8。此后再插入数据库中的内容都会按照UTF-8的编码来处理。
注意:在Linux中,终端方式中直接插入中文内容,可能并不会出现1406错误,但是这时插入的数据
是按照系统的默认编码进行处理。因此对编码为UTF-8的数据库,在显示数据的地方可能会出现乱码。
2、在Windows下,命令行窗口不支持UTF-8编码,所以使用“set names utf8;”不会达到转化中文的
效果。但是这个问题还是可以解决的:
(1)使用默认编码建立数据库。这种情况下就可以直接输入中文了,但是相应的问题,就是会
失去UTF-8编码的灵活性。特别是不利于软件的国际化。
(2)放弃命令行窗口登录MySQL,使用图形化客户端。客户端工具可以MySQL的官方网站上找到。
B. Mysql配置文件:
“在my.ini里找到sql- mode='STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION'把其中 的STRICT_TRANS_TABLES,去掉,或者把sql- mode=STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION注释掉,然 后重启mysql就ok了
支持插入中文的前提是:你的数据库编码和mysql连接所使用的字符集要相同,即:你的数据库(comment)的字符集是GBK的,那么你在数据库连接(mysql_connect)时要加上一句mysql_query('set
names
gbk');
这样的话就不会出现中文插入时出现乱码现象。UTF8字符集时与GBK同理。
还有疑问?