MySql修改数据库编码为UTF8避免造成乱码问题

时间:2024-01-24 22:11:59 

mysql 创建数据库时指定编码很重要,很多开发者都使用了默认编码,乱码问题可是防不胜防。制定数据库的编码可以很大程度上避免倒入导出带来的乱码问题。

网页数据一般采用UTF8编码,而数据库默认为latin 。我们可以通过修改数据库默认编码方式为UTF8来减少数据库创建时的设置,也能最大限度的避免因粗心造成的乱码问题。

我们遵循的标准是,数据库,表,字段和页面或文本的编码要统一起来
我们可以通过命令查看数据库当前编码: mysql> SHOW VARIABLES LIKE 'character%';
发现很多对应的都是 latin1,我们的目标就是在下次使用此命令时latin1能被UTF8取代。

第一阶段:
mysql设置编码命令


SET character_set_client = utf8;
SET character_set_connection = utf8;
SET character_set_database = utf8;
SET character_set_results = utf8;
SET character_set_server = utf8;


然后 mysql> SHOW VARIABLES LIKE 'character%'; 你可以看到全变为 utf8 。
但是,这只是一种假象

此种方式只在当前状态下有效,当重启数据库服务后失效。
所以如果想要不出现乱码只有修改my.ini文件,
从my.ini下手(标签下没有的添加,有的修改)
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
default-character-set=utf8
以上3个section都要加default-character-set=utf8,平时我们可能只加了mysqld一项。
然后重启mysql,执行
mysql> SHOW VARIABLES LIKE 'character%';
确保所有的Value项都是utf8即可。
但是可恶的事情又来了,
|character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | latin1 |
| character_set_system | utf8 注意 该配置| character_set_server | latin1 无法设置成UTF8 交互时候仍然会出现乱码。

第二阶段:找到下面这东东
X:\%path%\MySQL\MySQL Server 5.0\bin\MySQLInstanceConfig.exe
重新启动设置,将默认编码设置为utf8.这样就能达到我们所要的效果了。
mysql> SHOW VARIABLES LIKE 'character%';
+--------------------------+---------------------------------------------------------+
| Variable_name | Value |
+--------------------------+---------------------------------------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | C:\Program Files\MySQL\MySQL Server 5.0\share\charsets\ |
+--------------------------+---------------------------------------------------------+
8 rows in set
另外注意事项:

1、建表时加utf8,表字段的Collation可加可不加,不加时默认是utf8_general_ci了。


CREATE TABLE `tablename4` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`varchar1` varchar(255) DEFAULT NULL,
`varbinary1` varbinary(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8


2、网页xxx.php/jsp保存时选择utf8编码,页头最好加上
header('conten-type:text/html;charset=utf-8');
在执行CRUD操作前先执行一下
mysql_query("set names utf8");

-------------------------
连接数据库设置编码
jdbc:mysql://地址:3306/数据库名?characterEncoding=utf8
-------------------------
java中的常用编码UTF-8;GBK;GB2312;ISO-8859-1;
对应mysql数据库中的编码utf8;gbk;gb2312;latin1

标签:数据库编码,UTF8,乱码
0
投稿

猜你喜欢

  • 超酷的js图片轮播渐变效果

    2007-10-10 20:45:00
  • python中rc1什么意思

    2023-10-24 13:01:38
  • CSS属性与JavaScript 编码方法对照表

    2008-12-01 13:01:00
  • MySQL中的长事务示例详解

    2024-01-28 11:16:51
  • 教你恢复SQLSERVER的master系统库的方法

    2024-01-21 05:21:55
  • python利用logging模块实现根据日志级别打印不同颜色日志的代码案例

    2022-03-21 14:58:07
  • SQLServer日期函数总结案例详解

    2024-01-13 07:50:49
  • 如何使用conda和pip批量安装Python包

    2022-08-23 09:17:54
  • python sys.stdin和sys.stdout的用法说明

    2022-04-05 07:35:29
  • css设计的具有亲和力的表格

    2008-03-16 19:28:00
  • pycharm如何为函数插入文档注释

    2023-09-13 09:53:56
  • 基于python实现学生管理系统

    2021-11-24 21:07:48
  • JavaScript原型链详解

    2024-04-19 09:44:42
  • MySQL手动安装方法与中文解决方案

    2011-04-25 18:21:00
  • 如何把Mysql卸载干净(亲测有效)

    2024-01-16 09:06:06
  • python连接mongodb操作数据示例(mongodb数据库配置类)

    2023-05-01 17:21:17
  • 用Dreamweaver MX制作文字特效

    2011-06-14 09:49:47
  • flask循环导入的问题解决

    2023-10-01 10:28:52
  • Django视图层与模板层实例详解

    2022-01-24 10:20:09
  • Python调用飞书发送消息的示例

    2022-10-20 14:21:23
  • asp之家 网络编程 m.aspxhome.com