阿里云数据库RDS MySQL如何保证数据库字符编码正确?

作者阿里云代理 文章分类 分类:新闻快递 阅读次数 已被围观 1240

概述

本文主要介绍RDS MySQL如何保证数据库字符编码正确。

详细信息

阿里云提醒您:

如果您对实例或数据有修改、变更等风险操作,务必注意实例的容灾、容错能力,确保数据安全。

如果您对实例(包括但不限于ECS、RDS)等进行配置与数据修改,建议提前创建快照或开启RDS日志备份等功能。

如果您在阿里云平台授权或者提交过登录账号、密码等安全信息,建议您及时修改。

字符集是数据库设计过程中需要详细考虑的一点,您需要根据业务场景、用户数据等方面来综合考虑。

字符编码的介绍

1.登录RDS实例,请参考连接MySQL实例。

2.依次执行如下SQL语句,查看相应数据库的字符集。

use [$DB_Name];

show variables like '%character%';

注:[$DB_Name]为数据库名。

系统显示类似如下。

注:

▫以上参数必须保证除了character_set_filesystem外的参数都统一,才不会出现乱码的情况。

▫character_set_client、character_set_connection以及character_set_results是客户端的设置。

▫character_set_system、character_set_server以及character_set_database是服务器端的设置。

▫服务器端的参数优先级是character_set_database > character_set_server > character_set_system。

保证数据库字符编码正确

1.执行如下SQL语句,修改客户端字符集。

set names [$Character_Set]

注:[$Character_Set]为字符集。

2.执行如下SQL语句,修改character_set_database参数。

ALTER DATABASE [$DB_Name] CHARACTER SET = [$Character_Set] COLLATE = [$Rules];

注:[$Rules]为字符集规则。

3.登录RDS管理控制台,在页面左上角,选择实例所在地域。找到目标实例,单击实例ID。在左侧导航栏中单击 参数设置。

4.在可修改参数页签下查找到 character_set_server 进行修改,然后单击 确定。

提示:修改character_set_server参数需要重启实例,建议在业务低峰期进行操作。

5.在页面右上角单击 提交参数,在弹出的对话框中单击 确定,等待实例重启即可。

提示:该参数修改后,仅对开启高权限账号的实例后,创建的数据库有效,对当前数据库无效。

6.character_set_system暂时不提供更改,但是由于其优先级最低,因此影响不大。做完上述的设置之后基本上可以保证不会出现乱码,在代码中设置客户端字符编码时建议通过第1步的SQL语句来修改客户端的设置。

适用于

•云数据库 RDS MySQL 版

阿里云代理商  阿里云分销商

本公司销售:阿里云新/老客户,只要购买阿里云,即可享受折上折优惠!>

我有话说: