Home > Database > Mysql Tutorial > body text

Mysql数据库乱码总结_MySQL

WBOY
Release: 2016-06-01 13:44:23
Original
814 people have browsed it

bitsCN.com

 

今天又独到了Mysql乱码问题,过去总是匆匆的解决了就算了。这次我实在受不了了。每次都是迷迷糊糊的改好的。这次决定好好探索一把,看了很多资料及博客之后才理解了点。先记录下来。如有不对的请指正。1. 首先Mysql是在4.0之后才支持多字符集的。所以只有4.0之后才会出现这种问题。编码转换的规则就是,在输入数据时将编码由“客户端编码”转换为“服务器端编码”,输出时将数据由“服务器端编码”转换为“客户端编码”。 MySQL的字符集处理是这样的:1、发送请求。
Copy after login

  1)客户端发送请求到服务器端。

  2)服务器端会把请求的数据从客户端字符集(character_set_client)转成服务器连接字符集(character_set_connection)。

  3)然后服务器会检测存储区域(table,column)的字符集,

然后把数据从连接字符集(character_set_connection)转为存储区域(table,column)的字符集,然後再存储或者查询。

  2、返回请求。

  1)服务器将存储区域(table,column)的字符集转换成服务器连接字符集(character_set_connection)。

  2)将服务器连接字符集(character_set_connection)转换成结果字符集(character_set_results),再发送到客户端。

 

首先我们看下mysql>status;
Copy after login

/

我们可以看到四个字符集的设置。1.改变my.ini文件中的编码可以改变所有的字符集。2.set names "uf8" 可以改变 Client  conn这两个字符集。3.建立数据库时的设置编码可以改变DB 这个。知道了,原理之后我开始解决今天遇到的问题。1.在其他地方正常显示中文。但是在CMD中不能显示显示乱码。首先我设置了my.ini将字符集全部设置为utf8。个人感觉utf8是趋向标准的。然后数据库建立时设置为utf8.可是看到CMD查询出的是乱码。这是因为CMD.也就是我们熟知的windows下的dos是不支持utf8的。所以我设置输出到客户端编码方式转换成GBK即可。也就是set names gbk 。ok问题解决。作者 JavaNote
Copy after login
bitsCN.com
Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!