当前位置: 首页 > 图文教程 > 数据库 > MYSQL > MySQL数据库中的各种乱码及其解决方法

MYSQL
Linux环境MySQL服务器级优化讲解
MySQL在命名用过程中所遇到的常见问题
MySQL数据库只监听某个特定地址的方法
MySQL数据库管理必备工具 phpMyAdmin 3.0
MySQL中两种快速创建空表的方式的区别
讲解MySQL数据库的数据类型和建库策略
请正确认识MySQL对服务器端光标的限制
如何在MySQL查询结果集中得到记录行号
在SUSE10环境下安装和配置MySQL数据库
由浅入深讲解MySQL数据库索引的选择性
轻松掌握MySQL数据库锁机制的相关原理
一种特别简单的MySQL数据库安装方法
实例讲解如何配置MySQL数据库主从复制
MySQL数据库中的重要数据应当如何保护
详细讲解MySQL数据库对文件操作的封装
深入了解MySQL的数据类型以及建库策略
解决MySQL数据库中与优化器有关的问题
向MySQL数据库的表中录入数据的实用方法
MySQL数据库中的各种乱码及其解决方法
快速掌握怎样选择准备安装的 MySQL版本

MYSQL 中的 MySQL数据库中的各种乱码及其解决方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 41 ::
收藏到网摘: n/a

1.在使用MySQL和php的时候出现过中文乱码问题

(1) 只要是gb2312,gbk,utf8等支持多字节编码的字符集都可以储存汉字,当然,gb2312中的汉字数量远少于gbk,而gb2312,gbk等都可在utf8下编码

(2)用命令show variables like 'character\_set\_%';查看当前字符集设定:

以下为引用的内容:

mysql> show variables like 'character\_set\_%';

+--------------------------+--------+

| Variable_name            | Value  |

+--------------------------+--------+

| character_set_client     | gb2312 |

| character_set_connection | gb2312 |

| character_set_database   | gb2312 |

| character_set_filesystem | binary |

| character_set_results    | gb2312 |

| character_set_server     | latin1 |

| character_set_system     | utf8   |

+--------------------------+--------+

7 rows in set (0.02 sec)

(笔者在这里设置的字符是gb2312)

显示中文乱码主要有两个设置:character_set_connection 和character_set_results ,

如果你的这两个设置不支持中文编码,就会出现乱码,只要:set character_set_results =gbk;就设置中文编码了.

(3).set names charset_name;还可以一次性设置客户端的所有字符集.

2.在.NET中与mysql数据库的时候我也碰到显示不了中文字符的情况实现!

我的解决方法是在连接字符加上一个字符集CharSet=utf8;

以下为引用的内容:

<appSettings>

    <add key="Conn" value="Server=127.0.0.1;userid=root;password=test;
Database=game;Port=3306;CharSet=utf8;"/>

  </appSettings>

3.在PYthon中如果使用utf8编码的话

在创建数据的时候一定要加上default character set utf8 collate utf8_general_ci

不然输入中文的时候会出现:Data too long for column这样的提示信息!

create database test default character
set utf8 collate utf8_general_ci