`
gandilong
  • 浏览: 4510 次
  • 性别: Icon_minigender_1
  • 来自: 河南省
社区版块
存档分类
最新评论

Mysql中文乱码问题完美解决方案

 
阅读更多

MySQL会出现中文乱码的原因不外乎下列几点:
1.server本身设定问题,例如还停留在latin1
2.table的语系设定问题(包含character与collation)
3.客户端程式(例如php)的连线语系设定问题
强烈建议使用utf8!!!!
utf8可以兼容世界上所有字符!!!!
一、避免创建数据库及表出现中文乱码和查看编码方法
1、创建数据库的时候:CREATE DATABASE `test`
CHARACTER SET 'utf8'
COLLATE 'utf8_general_ci';
2、建表的时候 CREATE TABLE `database_user` (
`ID` varchar(40) NOT NULL default '',
`UserID` varchar(40) NOT NULL default '',
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

这3个设置好了,基本就不会出问题了,即建库和建表时都使用相同的编码格式。
但是如果你已经建了库和表可以通过以下方式进行查询。
1.查看默认的编码格式:
mysql> show variables like "%char%";
+--------------------------+---------------+
| Variable_name | Value |
+--------------------------+---------------+
| character_set_client | gbk |
| character_set_connection | gbk |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | gbk |
| character_set_server | utf8 |
| character_set_system | utf8 |
+--------------------------+-------------+
注:以前2个来确定,可以使用set names utf8,set names gbk设置默认的编码格式;

执行SET NAMES utf8的效果等同于同时设定如下:
SET character_set_client='utf8';
SET character_set_connection='utf8';
SET character_set_results='utf8';

2.查看test数据库的编码格式:
mysql> show create database test;
+------------+------------------------------------------------------------------------------------------------+
| Database | Create Database |
+------------+------------------------------------------------------------------------------------------------+
| test | CREATE DATABASE `test` /*!40100 DEFAULT CHARACTER SET gbk */ |
+------------+------------------------------------------------------------------------------------------------+

3.查看yjdb数据库的编码格式:
mysql> show create table yjdb;
| yjdb | CREATE TABLE `yjdb` (
`sn` int(5) NOT NULL AUTO_INCREMENT,
`type` varchar(10) NOT NULL,
`brc` varchar(6) NOT NULL,
`teller` int(6) NOT NULL,
`telname` varchar(10) NOT NULL,
`date` int(10) NOT NULL,
`count` int(6) NOT NULL,
`back` int(10) NOT NULL,
PRIMARY KEY (`sn`),
UNIQUE KEY `sn` (`sn`),
UNIQUE KEY `sn_2` (`sn`)
) ENGINE=MyISAM AUTO_INCREMENT=1826 DEFAULT CHARSET=gbk ROW_FORMAT=DYNAMIC |

二、避免导入数据有中文乱码的问题
1:将数据编码格式保存为utf-8
设置默认编码为utf8:
set names utf8;
设置数据库db_name默认为utf8:
ALTER DATABASE `db_name` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
设置表tb_name默认编码为utf8:
ALTER TABLE `tb_name` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

修改表字段字符编码:

alter table [table_name] modify [field_name] char(20) character set gbk;
导入:
LOAD DATA LOCAL INFILE 'C:\\utf8.txt' INTO TABLE yjdb;
2:将数据编码格式保存为ansi(即GBK或GB2312)
设置默认编码为gbk:
set names gbk;
设置数据库db_name默认编码为gbk:
ALTER DATABASE `db_name` DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;
设置表tb_name默认编码为gbk:
ALTER TABLE `tb_name` DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;
导入:
LOAD DATA LOCAL INFILE 'C:\\gbk.txt' INTO TABLE yjdb;

注:1.UTF8不要导入gbk,gbk不要导入UTF8;
2.dos下不支持UTF8的显示;
三、解决网页中乱码的问题
 
将网站编码设为 utf-8,这样可以兼容世界上所有字符。
  如果网站已经运作了好久,已有很多旧数据,不能再更改简体中文的设定,那么建议将页面的编码设为 GBK, GBK与GB2312的区别就在于:GBK能比GB2312显示更多的字符,要显示简体码的繁体字,就只能用GBK。
1.编辑/etc/my.cnf ,在[mysql]段加入default_character_set=utf8;
2.在编写Connection URL时,加上?useUnicode=true&characterEncoding=utf-8参;
3.在网页代码中加上一个"set names utf8"或者"set names gbk"的指令,告诉MySQL连线内容都要使用
utf8或者gbk;

分享到:
评论

相关推荐

    Mysql中文乱码问题完美解决方案.pdf

    以下是一些解决中文乱码问题的方法: 1. **命令行导入数据时的设置** 当在DOS命令行下导入SQL文件时,确保在进入MySQL的bin目录后,使用`mysql -uroot -p 密码 数据库名称 要恢复的文件.sql`命令。如果遇到乱码...

    Mysql中文乱码问题完美解决方案.docx

    以下是一些解决中文乱码问题的详细步骤和知识点: 1. **MySQL服务器配置**: - 在MySQL的配置文件(如`my.cnf`或`my.ini`)中,为服务器部分 `[mysqld]` 添加 `default-character-set=utf8` 或者根据需求设置为...

    Mysql中文乱码问题完美解决方案宣贯.pdf

    综上所述,解决MySQL中文乱码问题需要从多个层面进行检查和调整,包括服务器设置、数据库和表的创建、客户端连接以及数据传输的编码。通过正确配置这些环节,可以确保中文字符在MySQL中的正确显示和处理。

    关于Mysql中文乱码问题该如何解决(乱码问题完美解决方案)

    给大家介绍关于Mysql中文乱码问题该如何解决(乱码问题完美解决方案)的相关资料,还给大家收集些关于MySQL会出现中文乱码原因常见的几点,小伙伴快来看看吧

    网页中文乱码完美解决方案.pdf

    网页中文乱码完美解决方案 本文档旨在解决网页中文乱码问题,提供了三个方面的解决方案:APACHE 服务器设置、PHP 编码问题和 MYSQL 数据库的表以及字段编码。 APACHE 服务器设置 APACHE 服务器的配置文件中有一行...

    完美解决PHP中文乱码问题

    ### 完美解决PHP中文乱码问题:深入解析与实用指南 #### 一、理解PHP中文乱码问题 在PHP编程中,中文乱码问题是开发者经常遇到的挑战,尤其是在处理多语言网站或应用时。这一问题主要源于字符集编码不一致,即数据...

    完美解决PHP中文乱码

    ### 完美解决PHP中文乱码 #### 一、PHP网页的编码问题 在处理PHP中文乱码问题时,首要任务是确保PHP文件本身的编码与其所声明的网页编码相匹配。这涉及到设置正确的HTTP头部信息以及调整文件的实际编码格式。 ###...

    API自动化解决方案[开源项目]基于RestAssured的接口自动化测试框架完美版.docx

    ### API自动化解决方案——基于RestAssured的接口自动化测试框架 #### 概述 随着Web应用程序逐渐采用RESTful架构,API接口的重要性日益凸显。RESTful API不仅简化了Web开发流程,而且提高了不同系统间的互操作性。...

    emoji入库mysql注意事项除了更改utf8mb4最大的坑在这里

    #### 三、解决方案:使用UTF8MB4字符集 为了解决上述问题,最简单有效的方法就是将MySQL的字符集设置为`utf8mb4`。这个字符集能够支持最多四个字节的字符编码,从而可以完美兼容emoji等四字节字符。 - **在安装...

    FastReport 4.13 完美汉化版本

    在4.13版本中,即使在PDF中使用宋体,也不会出现乱码问题,确保了中文显示的准确性。 4. 源码提供:这个版本提供源码,意味着开发者可以查看和修改FastReport的内部实现,这对于高级用户或希望进行深度定制的开发者...

    FLASH+php 聊天室完美中文版

    综上所述,"FLASH+php 聊天室完美中文版"是一个结合了Flash的用户体验和PHP的后端处理能力的实时聊天解决方案,涉及到了前端与后端的通信、中文字符处理、安全性以及性能优化等多个方面的技术知识。

    Delphi IntraWeb 中文支持

    针对这些常见问题,网络上出现了一些补丁和解决方案,以确保Intraweb能够正确地显示和处理中文内容。 1. **编码问题**:在Web开发中,编码问题是最常见的问题之一。Intraweb 默认可能使用的是ASCII或UTF-8编码,而...

Global site tag (gtag.js) - Google Analytics