`
shuany
  • 浏览: 253917 次
  • 性别: Icon_minigender_1
  • 来自: 中国
社区版块
存档分类
最新评论

又一次成功解决Mysql乱码问题

阅读更多

转载:http://www.busfly.cn/post/mysql-utf8.html

 

mysql -h  ip  -P 端口 -u用户 -p密码

 

又一次成功解决Mysql乱码问题
(MYSQL,问题,MYSQL数据库,乱码)

以前在我的博客上发过文章总结我遇到的数据及网页上中文乱码的处理办法[再谈乱码问题,如何解决MYSQL数据中文乱码问题 ] [解决jsp,tomcat,MYSQL下中文乱码问题 ] ,但是,不幸的是,今天又遇到了,用过以前的办法,没能解决,我相信绝对不是网页的问题.因为,我在MYSQL里直接添加中文的数据能在网页上正常显示, 可是在网页中操作添加的数据,到MYSQL数据库里一看,全是???问号.我下断点,跟踪进去看了,程序中最后处理到数据库操作时,还是中文,操作到数据 库后,就是?问号了.

后来找了很多资料,终于把这个问题解决,由于能直接在MYSQL数据库里添加中文数据,并且能正常显示,说明我的表都使用了正确的字符编码,经过查看后,确认了,我全部的表以及字段都使用了UTF-8的编码,但是为什么程序添加的中文数据就不行呢?

其 实,原因在于MYSQL服务器使用的默认编码,以及数据库的默认编码,很多人已经很小心的在建立表时关注表的字符编码,却忽略了数据库的字符编码,而在没 指定数据库的字符编码时,创建的数据库就使用MYSQL服务器的默认编码,但是,如果MYSQL服务器的配置文件没有指定编码时,很可能就是使用的 latin1编码.
查看服务器和数据库使用何种编码的MYSQL命令为:SHOW VARIABLES LIKE 'character_set_%';  以及 SHOW VARIABLES LIKE 'collation_%'; 看到里面使用的编码了,我本应该使用的是utf8,所以,不是utf8的,那就说明问题在这里了.

运行命令:SHOW VARIABLES LIKE 'character_set_%'; 结果如下
'character_set_client', 'utf8'
'character_set_connection', 'utf8'
'character_set_database', 'latin1'
'character_set_filesystem', 'binary'
'character_set_results', 'utf8'
'character_set_server', 'latin1'
'character_set_system', 'utf8'
'character_sets_dir', 'D:\soft_work\mysql\share\charsets\'
果然发现有几个不对的
运行命令:SHOW VARIABLES LIKE 'collation_%'; 结果如下
'collation_connection', 'utf8_general_ci'
'collation_database', 'latin1_general_ci'
'collation_server', 'latin1_general_ci'

那怎么办呢,只要把那几个的编码改成utf8的,那应该就可以了.
1: 在Mysql的配置文件 my.ini (一般在c:/windows/下面) 里加上服务器的默认编码配置: default-character-set=utf8
2: 修 改你的数据库的字符编码:进入Mysql数据库,通过命令修改你的数据库字符编码: ALTER DATABASE `databaseName` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci  (修改后需要重启Mysql数据库)
3: 如果你的表以及表里的字段使用了不正确的字符编码,同样需要修正过来:命令:
 修改表的编码: ALTER TABLE `tableName` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci
 修改字段的编码: ALTER TABLE `tableName` CHANGE `dd` `dd` VARCHAR( 45 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL
(做好了时,再跑一下上面那两个查看字符编码的命令,看看是否全部都变成了utf8)

4: 如 果还无效的话,再尝试使用这个MYSQL数据库连接字符串:  jdbc:mysql://localhost:3306/xxxx?useUnicode=true&characterEncoding=UTF-8 (有时可能需要将符号(&)转码写成(&))

 

==============================================================
补充材料一:
==============================================================
mysql字符编码是版本4.1引入的,支持多国语言,而且一些特性已经超过了其他的数据库系统。
我们可以在MySQL Command Line Client 下输入如下命令查看mysql的字符集
mysql> SHOW CHARACTER SET;
+----------+-----------------------------+---------------------+--------+
| Charset  | Description                 | Default collation   | Maxlen |
+----------+-----------------------------+---------------------+--------+
| big5     | Big5 Traditional Chinese    | big5_chinese_ci     | 2      |
| dec8     | DEC West European           | dec8_swedish_ci     | 1      |
| cp850    | DOS West European           | cp850_general_ci    | 1      |
| hp8      | HP West European            | hp8_english_ci      | 1      |
| koi8r    | KOI8-R Relcom Russian       | koi8r_general_ci    | 1      |
| latin1   | cp1252 West European        | latin1_swedish_ci   | 1      |
| latin2   | ISO 8859-2 Central European | latin2_general_ci   | 1      |
| swe7     | 7bit Swedish                | swe7_swedish_ci     | 1      |
| ascii    | US ASCII                    | ascii_general_ci    | 1      |
| ujis     | EUC-JP Japanese             | ujis_japanese_ci    | 3      |
| sjis     | Shift-JIS Japanese          | sjis_japanese_ci    | 2      |
| hebrew   | ISO 8859-8 Hebrew           | hebrew_general_ci   | 1      |
| tis620   | TIS620 Thai                 | tis620_thai_ci      | 1      |
| euckr    | EUC-KR Korean               | euckr_korean_ci     | 2      |
| koi8u    | KOI8-U Ukrainian            | koi8u_general_ci    | 1      |
| gb2312   | GB2312 Simplified Chinese   | gb2312_chinese_ci   | 2      |
| greek    | ISO 8859-7 Greek            | greek_general_ci    | 1      |
| cp1250   | Windows Central European    | cp1250_general_ci   | 1      |
| gbk      | GBK Simplified Chinese      | gbk_chinese_ci      | 2      |
| latin5   | ISO 8859-9 Turkish          | latin5_turkish_ci   | 1      |
| armscii8 | ARMSCII-8 Armenian          | armscii8_general_ci | 1      |
| utf8     | UTF-8 Unicode               | utf8_general_ci     | 3      |
| ucs2     | UCS-2 Unicode               | ucs2_general_ci     | 2      |
| cp866    | DOS Russian                 | cp866_general_ci    | 1      |
| keybcs2  | DOS Kamenicky Czech-Slovak  | keybcs2_general_ci  | 1      |
| macce    | Mac Central European        | macce_general_ci    | 1      |
| macroman | Mac West European           | macroman_general_ci | 1      |
| cp852    | DOS Central European        | cp852_general_ci    | 1      |
| latin7   | ISO 8859-13 Baltic          | latin7_general_ci   | 1      |
| cp1251   | Windows Cyrillic            | cp1251_general_ci   | 1      |
| cp1256   | Windows Arabic              | cp1256_general_ci   | 1      |
| cp1257   | Windows Baltic              | cp1257_general_ci   | 1      |
| binary   | Binary pseudo charset       | binary              | 1      |
| geostd8  | GEOSTD8 Georgian            | geostd8_general_ci  | 1      |
| cp932    | SJIS for Windows Japanese   | cp932_japanese_ci   | 2      |
| eucjpms  | UJIS for Windows Japanese   | eucjpms_japanese_ci | 3      |
+----------+-----------------------------+---------------------+--------+
36 rows in set (0.02 sec)
更多mysql的字符集知识可以参考本论坛的
http://www.phpfans.net/bbs/viewt ... &extra=page%3D1

字 符集支持(Character Set Support)有两个方面:字符集(Character set)和排序方式(Collation)。对于字符集的支持细化到四个层次: 服务器(server),数据库(database),数据表(table)和连接(connection)。
查看系统的字符集和排序方式的设定可以通过下面的两条命令:
mysql> SHOW VARIABLES LIKE 'character_set_%';
+--------------------------+-------------------------------------------+
| Variable_name            | Value                                     |
+--------------------------+-------------------------------------------+
| character_set_client     | latin1                                    |
| character_set_connection | latin1                                    |
| character_set_database   | latin1                                    |
| character_set_filesystem | binary                                    |
| character_set_results    | latin1                                    |
| character_set_server     | latin1                                    |
| character_set_system     | utf8                                      |
| character_sets_dir       | D:\MySQL\MySQL Server 5.0\share\charsets\ |
+--------------------------+-------------------------------------------+
8 rows in set (0.06 sec)
mysql> SHOW VARIABLES LIKE 'collation_%';
+----------------------+-------------------+
| Variable_name        | Value             |
+----------------------+-------------------+
| collation_connection | latin1_swedish_ci |
| collation_database   | latin1_swedish_ci |
| collation_server     | latin1_swedish_ci |
+----------------------+-------------------+
3 rows in set (0.02 sec)


==============================================================
补充材料二: mysql字符集编码 详细说明
--------------------------------------------------------------
原文地址:http://www.phpfans.net/bbs/viewthread.php?tid=296&extra=page%3D1
==============================================================
mysql字符集编码
字符集和整理
整理 描述
armscii8   (ARMSCII-8 Armenian)
armscii8_bin   亚美尼亚语,   二进制
armscii8_general_ci  亚美尼亚语,   不区分大小写
ascii    (US ASCII)
ascii_bin   西欧 (多语言),   二进制
ascii_general_ci  西欧 (多语言),   不区分大小写
big5    (Big5 Traditional Chinese)
big5_bin   繁体中文,   二进制
big5_chinese_ci  繁体中文,   不区分大小写
binary    (Binary pseudo charset)
binary    二进制
cp1250    (Windows Central European)
cp1250_bin   中欧 (多语言),   二进制
cp1250_croatian_ci  克罗地亚语,   不区分大小写
cp1250_czech_cs  捷克语,   区分大小写
cp1250_general_ci  中欧 (多语言),   不区分大小写
cp1251    (Windows Cyrillic)
cp1251_bin   西里尔语 (多语言),  二进制
cp1251_bulgarian_ci  保加利亚语,   不区分大小写
cp1251_general_ci  西里尔语 (多语言),  不区分大小写
cp1251_general_cs  西里尔语 (多语言),  区分大小写
cp1251_ukrainian_ci  乌克兰语,   不区分大小写
cp1256    (Windows Arabic)
cp1256_bin   阿拉伯语,   二进制
cp1256_general_ci  阿拉伯语,   不区分大小写
cp1257    (Windows Baltic)
cp1257_bin   巴拉克语 (多语言),  二进制
cp1257_general_ci  巴拉克语 (多语言),  不区分大小写
cp1257_lithuanian_ci  立陶宛语,   不区分大小写
cp850    (DOS West European)
cp850_bin   西欧 (多语言),   二进制
cp850_general_ci  西欧 (多语言),   不区分大小写
cp852    (DOS Central European)
cp852_bin   中欧 (多语言),   二进制
cp852_general_ci  中欧 (多语言),   不区分大小写
cp866    (DOS Russian)
cp866_bin   俄语,    二进制
cp866_general_ci  俄语,    不区分大小写
cp932    (SJIS for Windows Japanese)
cp932_bin   日语,    二进制
cp932_japanese_ci  日语,    不区分大小写
dec8    (DEC West European)
dec8_bin   西欧 (多语言),   二进制
dec8_swedish_ci  瑞典语,   不区分大小写
eucjpms   (UJIS for Windows Japanese)
eucjpms_bin   日语,    二进制
eucjpms_japanese_ci  日语,    不区分大小写
euckr (EUC-KR Korean)
euckr_bin   朝鲜语,   二进制
euckr_korean_ci  朝鲜语,   不区分大小写
gb2312    (GB2312 Simplified Chinese)
gb2312_bin   简体中文,   二进制
gb2312_chinese_ci  简体中文,   不区分大小写
gbk    (GBK Simplified Chinese)
gbk_bin   简体中文,   二进制
gbk_chinese_ci   简体中文,   不区分大小写
geostd8   (GEOSTD8 Georgian)
geostd8_bin   乔治亚语,   二进制
geostd8_general_ci  乔治亚语,   不区分大小写
greek    (ISO 8859-7 Greek)
greek_bin   希腊语,   二进制
greek_general_ci  希腊语,   不区分大小写
hebrew    (ISO 8859-8 Hebrew)
hebrew_bin   希伯来语,   二进制
hebrew_general_ci  希伯来语,   不区分大小写
hp8    (HP West European)
hp8_bin   西欧 (多语言),   二进制
hp8_english_ci   英语,    不区分大小写
keybcs2   (DOS Kamenicky Czech-Slovak)
keybcs2_bin   捷克斯洛伐克语,   二进制
keybcs2_general_ci  捷克斯洛伐克语,  不区分大小写
koi8r    (KOI8-R Relcom Russian)
koi8r_bin   俄语,    二进制
koi8r_general_ci  俄语,    不区分大小写
koi8u    (KOI8-U Ukrainian)
koi8u_bin   乌克兰语,   二进制
koi8u_general_ci  乌克兰语,   不区分大小写
latin1    (cp1252 West European)
latin1_bin   西欧 (多语言),   二进制
latin1_danish_ci  丹麦语,   不区分大小写
latin1_general_ci  西欧 (多语言),   不区分大小写
latin1_general_cs  西欧 (多语言),   区分大小写
latin1_german1_ci  德语 (字典),   不区分大小写
latin1_german2_ci  德语 (电话本),   不区分大小写
latin1_spanish_ci  西班牙语,   不区分大小写
latin1_swedish_ci  瑞典语,   不区分大小写
整理 描述
latin2    (ISO 8859-2 Central European)
latin2_bin   中欧 (多语言),   二进制
latin2_croatian_ci  克罗地亚语,   不区分大小写
latin2_czech_cs  捷克语,   区分大小写
latin2_general_ci  中欧 (多语言),   不区分大小写
latin2_hungarian_ci  匈牙利语,   不区分大小写
latin5    (ISO 8859-9 Turkish)
latin5_bin   土耳其语,   二进制
latin5_turkish_ci  土耳其语,   不区分大小写
latin7    (ISO 8859-13 Baltic)
latin7_bin   巴拉克语 (多语言),  二进制
latin7_estonian_cs  爱沙尼亚语,   区分大小写
latin7_general_ci  巴拉克语 (多语言),  不区分大小写
latin7_general_cs  巴拉克语 (多语言),  区分大小写
macce    (Mac Central European)
macce_bin   中欧 (多语言),   二进制
macce_general_ci  中欧 (多语言),   不区分大小写
macroman   (Mac West European)
macroman_bin   西欧 (多语言),   二进制
macroman_general_ci  西欧 (多语言),   不区分大小写
sjis    (Shift-JIS Japanese)
sjis_bin   日语,    二进制
sjis_japanese_ci  日语,    不区分大小写
swe7    (7bit Swedish)
swe7_bin   瑞典语,   二进制
swe7_swedish_ci  瑞典语,   不区分大小写
tis620    (TIS620 Thai)
tis620_bin   泰语,    二进制
tis620_thai_ci   泰语,    不区分大小写
ucs2    (UCS-2 Unicode)
ucs2_bin Unicode  (多语言),   二进制
ucs2_czech_ci   捷克语,   不区分大小写
ucs2_danish_ci   丹麦语,   不区分大小写
ucs2_esperanto_ci  未知,    不区分大小写
ucs2_estonian_ci  爱沙尼亚语,   不区分大小写
ucs2_general_ci  Unicode (多语言),  不区分大小写
ucs2_hungarian_ci  匈牙利语,   不区分大小写
ucs2_icelandic_ci  冰岛语,   不区分大小写
ucs2_latvian_ci  拉脱维亚语,   不区分大小写
ucs2_lithuanian_ci  立陶宛语,   不区分大小写
ucs2_persian_ci  波斯语,   不区分大小写
ucs2_polish_ci   波兰语,   不区分大小写
ucs2_roman_ci   西欧,    不区分大小写
ucs2_romanian_ci  罗马尼亚语,   不区分大小写
ucs2_slovak_ci   斯洛伐克语,   不区分大小写
ucs2_slovenian_ci  斯洛文尼亚语,   不区分大小写
ucs2_spanish2_ci  传统西班牙语,   不区分大小写
ucs2_spanish_ci  西班牙语,   不区分大小写
ucs2_swedish_ci  瑞典语,   不区分大小写
ucs2_turkish_ci  土耳其语,   不区分大小写
ucs2_unicode_ci  Unicode (多语言),  不区分大小写
ujis    (EUC-JP Japanese)
ujis_bin   日语,    二进制
ujis_japanese_ci  日语,    不区分大小写
utf8    (UTF-8 Unicode)
utf8_bin   Unicode (多语言),  二进制
utf8_czech_ci   捷克语,   不区分大小写
utf8_danish_ci   丹麦语,   不区分大小写
utf8_esperanto_ci  未知,    不区分大小写
utf8_estonian_ci  爱沙尼亚语,   不区分大小写
utf8_general_ci  Unicode (多语言),  不区分大小写
utf8_hungarian_ci  匈牙利语,   不区分大小写
utf8_icelandic_ci  冰岛语,   不区分大小写
utf8_latvian_ci  拉脱维亚语,   不区分大小写
utf8_lithuanian_ci  立陶宛语,   不区分大小写
utf8_persian_ci  波斯语,   不区分大小写
utf8_polish_ci   波兰语,   不区分大小写
utf8_roman_ci   西欧,    不区分大小写
utf8_romanian_ci  罗马尼亚语,   不区分大小写
utf8_slovak_ci   斯洛伐克语,   不区分大小写
utf8_slovenian_ci  斯洛文尼亚语,   不区分大小写
utf8_spanish2_ci  传统西班牙语,   不区分大小写
utf8_spanish_ci  西班牙语,   不区分大小写
utf8_swedish_ci  瑞典语,   不区分大小写
utf8_turkish_ci  土耳其语,   不区分大小写
utf8_unicode_ci  Unicode (多语言),  不区分大小写

分享到:
评论

相关推荐

    PHP MYSQL乱码问题,使用SET NAMES utf8校正

    问号乱码,找了一些资料原来是在读取之前进行一次编码设置: 复制代码 代码如下: create table tablename ( id int not null auto_increment, title varchar(20) not null, contnet varchar(300) defalut null, ...

    再推荐一款免费的PHP CMS内容管理系统.zip

    【描述】"再推荐一款免费的PHP CMS内容管理系统.zip" 强调了这是又一次推荐,意味着可能之前已经介绍过类似系统,而现在又有一个新的选项。".zip"表明这是一个压缩文件,里面可能包含了该CMS系统的安装文件、文档、...

    最新版appserv和yourphp

    Appserv-win32-2.6.0 (2).exe这个文件名表明这是Appserv的Windows 32位版本,版本号为2.6.0的第二次更新,它通常包含预设配置,只需简单几步就能在本地计算机上启动并运行一个完整的PHP开发环境。 【Yourphp】Your...

    JAVA自学之路

    经常的进行知识难点的查询,如果一个问题牵扯的面比较广,就干脆到网上搜索一些相关的专题,比如“java 乱码 mysql” “oracle 创建用户”等等,如果有必要,不要犯懒,勤动手写一些小小的测试程序,来弄明白知识点...

    基于PHP的薇晓朵橙蓝地方门户 Discuz模板 v1 GBKUTF8版.zip

    薇晓朵橙蓝地方门户模板v1则是对这一框架的一次定制化设计,旨在提升用户体验,同时展示出地方门户的特色和魅力。 GBK和UTF8是两种常见的字符编码格式。GBK是GB2312编码的扩展,支持更多的汉字和其他字符,主要在...

    批量读取txt文件导入数据库Demo实例

    - **缓冲区与流**:为了处理大型文件,可以使用缓冲区读取,避免一次性加载整个文件导致内存溢出。Python的`io`模块提供了`BufferedReader`类,支持分块读取。 - **文件编码**:确保正确识别文件的编码,例如UTF-8...

    jpivot学习总结.doc

    JPivot 是一套基于 Mondrian 的 OLAP 前端展现工具,它提供了一套标签库来解决的 OLAP 的展现层问题。 在一个 JSP 页面当中,如果要使用 JPivot 标签库,除了要配置相关的配置文件外,我们需要在 JSP 头的位置声明...

    对有自增长字段的表导入数据注意事项

    为了提高效率,可以采用批量插入的方式,一次性处理多条数据。例如,在SQL中,可以使用INSERT INTO...VALUES语句的多个值列表,或者使用BULK INSERT命令(在SQL Server中)来实现。 7. **性能优化**: 在大型数据...

    ssh(structs,spring,hibernate)框架中的上传下载

    原来是BlobByteArrayType数据类型本身具体数据访问的功能,它通过LobHandler将两次数据访问的动作隐藏起来,使Blob字段的操作在表现上和其他一般字段业类型无异,所以LobHandler即是那个"苦了我一个,幸福十亿人"的...

Global site tag (gtag.js) - Google Analytics