首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL字符集修改实战教程

本篇文章将会介绍 utf8 修改成 utf8mb4 字符集的方法。...这里简单讲下修改方法。 系统参数修改 首先应该修改系统字符集参数,这样以后创建的库表默认字符集就是 utf8mb4 了。...同样的,对于已经创建的表,修改全局及数据库的字符集并不会影响原表及字段的字符集。...原有的 utf8 表可以采用如下方法修改: # 修改字符集 alter table `tb_name` default character set utf8mb4; # 修改某字段字符集 alter...对于线上环境,若要修改字符集,一定要做好评估,最好可以在业务低峰期停机修改修改前一定要先备份。若无停机时间,可以考虑先在备库修改,然后再主备切换,不过这样做会更麻烦。

2K10

字符集与字符编码的区别与演进(ASCII、GBK、UNICODE)

演进:GB2312(2字节)→扩展繁体字→GBK(2字节)→扩展少数民族中日韩等→GB18030国家标准(4字节)。...注意GBK都是向下兼容的,即GB18030兼容GB2312,因为使用的编码位置没有重叠。 1.3.1 大五码 Big5码是一套双位元组字符集,使用了双八码储存方法,以两个字节来安放一个字。...具体来说,定义的是下列字节: 范围 第1字节 第2字节 编码数 字数 水准GBK/1 A1–A9 A1–FE 846 717 水准GBK/2 B0–F7 A1–FE 6,768 6,763 水准GBK/...3 81–A0 40–FE (7F除外) 6,080 6,080 水准GBK/4 AA–FE 40–A0 (7F除外) 8,160 8,160 水准GBK/5 A8–A9 40–A0 (7F除外) 192...2.3 GBK 事实上我们使用的GBK、GB18030都是标准,但由于我们的标准只对应一套特定的字符集,所以可以认为GBK就是字符集

1.1K20

警示:AL32UTF8字符集不是ZHS16GBK字符集的超集

今天有客户向我咨询:数据库由ZHS16GBK字符集修改为AL32UTF8字符集,发现中文的数据中小部分出现乱码,客户认为AL32UTF8明明可以支持更多的文字,不应该出现这样的情况才对。...----------------------------------- AMERICAN_AMERICA.ZHS16GBK 2.尝试修改字符集为AL32UTF8 直接尝试修改,会发现Oracle明确给出错误提示...这就说明我们要改的AL32UTF8字符集并不是ZHS16GBK的超集。...而客户端是Windows,chcp结果是936,也就是ZHS16GBK,这也进一步说明了ZHS16GBK和AL32UTF8字符集的不同。...同时实验还验证,如果数据库字符集本身是AL32UTF8,想修改成为ZHS16GBK字符集,也是一样的情况,需要加internal_use参数才可以转换,也就是说这种转换一样可能出现乱码,不过这个情况反倒好理解

1.7K60

修改字符集的注意那些事儿

一 前言 最近有开发同学遇到emoji显示问题,表结构是utf8mb4字符集,但是不支持emoji表情字符。我们在解决字符集问题的时候也重新认识了修改字符集操作的影响。...修改表的默认字符集只对表的新增字段有效,对老的字段无效,不会修改老的数据的字符集类型。 初始化表数据的时候 我们向字符集类型utf8的c1字段插入了emoji字符。查询出来是乱码。...2.2 修改表的字符集 ALTER TABLE t1 CONVERT TO CHARACTER SET utf8mb4; convert to charset 关键字会转换表的默认字符集以及字段的字符集...三 总结 1.修改表的默认字符集,仅仅修改元数据,支持online ddl ,但是适应convert 转换表和字段的字符集的时候会锁表。 2.修改表的字符集和字段的字符集仅仅对新增数据有效。...使用alert table defult charset 模式修改字符集可能带来字段字符集和表字符集不一样的情况。

66120

【Oracle字符集】识别及转换导出文件的字符集

,Solaris是Big-Endians,Linux是Little-Endians,所以Linux上的输出通过交换可以得到: 0303 5445 58504f52 …....最常见的转换发生在从US7ASCII到ZHS16GBK之间。 由于很多数据库最初以US7ASCII字符集存储中文,单纯通过导出导入是无法完成字符集转换的。...对于这种情况,可以通过设置导出字符集为US7ASCII,原样导出数据;导出后修改导出文件的第二、三字符,修改0001为0354,这样就可以将US7ASCII字符集的数据正确导入到ZHS16GBK的数据库中...修改完成之后,可以导入修改后的DMP文件: E:\nls2>set NLS_LANG=AMERICAN_AMERICA.ZHS16GBK E:\nls2>imp eygle/eygle file=Sus7ascii-Cus7ascii-exp817...如果导出文件使用的字符集是US7ASCII,目标数据库的字符集是ZHS16GBK,就可以使用create database的方法来修改,具体操作如下: ? ?

3.5K40

修改及查看mysql数据库的字符集

Liunx下修改MySQL字符集: 1.查找MySQL的cnf文件的位置 find / -iname ‘*.cnf’ -print /usr/share/mysql/my-innodb-heavy-4G.cnf...character_sets_dir | /usr/share/mysql/charsets/ | +————————–+—————————-+ 8 rows in set (0.02 sec) mysql> 其他的一些设置方法: 修改数据库的字符集...| collation_database | utf8_general_ci | | collation_server | utf8_general_ci | +———————-+—————–+ 3.修改默认字符集...(1) 最简单的修改方法,就是修改mysql的my.ini文件中的字符集键值, 如 default-character-set = utf8 character_set_server = utf8 修改完后...character_set_system | utf8 | | character_sets_dir | D:”mysql-5.0.37″share”charsets” | +————————–+———————————+ (2) 还有一种修改字符集的方法

4K90

GB2312、GBK、GB18030 这几种字符集的主要区别是什么?

1 GB2312-80 GB 2312 或 GB 2312-80 是中国国家标准简体中文字符集,全称《信息交换用汉字编码字符集·基本集》,又称 GB 0,由中国国家标准总局发布,1981 年 5...对于人名、古汉语等方面出现的罕用字,GB 2312 不能处理,这导致了后来 GBK 及 GB 18030 汉字字符集的出现。...GBK 编码区分三部分: 汉字区 包括 GBK/2:OXBOA1-F7FE, 收录 GB 2312 汉字 6763 个,按原序排列; GBK/3:OX8140-AOFE,收录 CJK 汉字 6080...图形符号区 包括 GBK/1:OXA1A1-A9FE,除 GB 2312 的符号外,还增补了其它符号 GBK/5:OXA840-A9AO,扩除非汉字区。...3 GB18030 GB 18030,全称:国家标准 GB 18030-2005《信息技术中文编码字符集》,是中华人民共和国现时最新的内码字集,是 GB 18030-2000《信息技术信息交换用汉字编码字符集基本集的扩充

2.2K31

升级迁移:利用DMU修改数据库字符集

表示日期和数字格式,第三位 ZHS16GBK 表示字符集。...通常情况下,数据库字符集不轻易修改,如果要修改,一般可以简单采用下面两种方法可行: 1. 如果需要修改字符集,通常需要导出数据库数据,重建数据库,再导入数据库数据的方式来转换。 2....通过 ALTER DATABASE CHARACTER SET|[INTERNAL_USE] 语句修改字符集,但创建数据库后修改字符集是有限制的,只有新的字符集是当前字符集的超集时才能修改数据库字符集...我们将原来的 zhs16gbk 的数据库字符集,转成al32utf8的字符集。...要正确显示数据库中的字符,需要也设置成 gbk SecureCRT登录数据库后: 如果设置成gbk,才能正确显示: 总体来说 nls_lang 的作用是告诉 oracle 数据库服务器,当前的客户端用的是哪个字符集

2.2K100

【程序源代码】Oracle19c修改字符集操作

关键字:oracle安装 昨天安装了个oracle19c,但在导入数据库时发现原来数据库的字符集设置错了,导致数据库文件无法正常导入并还原。今天又折腾了一半天查找如果修改oracle的字符集的操作。...SQL>ALTER DATABASE CHARACTER SET ZHS16GBK; ALTER DATABASE CHARACTER SET ZHS16GBK * ERROR at line 1...: ORA-12712: new character set must be a superset of old character set 提示我们的字符集:新字符集必须为旧字符集的超集,这时我们可以跳过超集的检查做更...改: SQL> ALTER DATABASE character set INTERNAL_USE ZHS16GBK; Database altered....SQL> select * from v$nls_parameters; 略 在内容中找下NLS_CHARACTERSET,这个值:ZHS16GBK 19 rows selected.

4.2K20
领券