首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用shell 批量更改 mysql字符集

开始之前 ---- 这里还有一个mysql字符乱码的例子,部署redmine过程中,mysql数据库使用了默认的字符集,导致含有中文内容为乱码。...执行脚本 bash -x convert_mysql_charset.sh MySql 字符集 ---- mysql 对于字符集的设置有四个层次: 服务器(server) 数据库(database...6)创建一张表,表默认的字符集被设定为 character_set_database,也就是这个数据库默认的字符集。 7)添加字段,除非明确指定,否则缺省的字符集就是表默认的字符集; 2....查看默认字符集默认情况下,mysql字符集是 latin1。...对于已经保存在mysql数据库的数据,可以使用shell脚本+alter语句批量更改字符集。 欢迎关注微信公众号: 运维录

1.7K10
您找到你想要的搜索结果了吗?
是的
没有找到

MYSQL 生产环境字段更改的failed的问题

早上看到微信一个银行的同学问了小问题,希望他不要背锅,具体问题是MYSQL 一个50G的表要更改字段,将一个字段从varchar(3) 改成varchar(6). MYSQL 5.7 官版。...在这种情况下,所需的长度字节数从1更改为2,这仅由表副本支持(ALGORITHM = COPY)。...表上的元数据锁可以防止对表结构的更改。这种锁定方法意味着一个会话内的事务正在使用的表,不能在DDL状态下使用。...注:到目前为止MYSQL 在修改字段方面,对比其他数据库还是要注意的地方多多,当然MYSQL 8 已经添加了 instant 让修改字段变得更让人放心。...但目前MYSQL5.X PT-OSC GH-OST等等的工具还是用起来,终归是不希望出现意外的情况。

1.8K30

MySQL 批量修改所有表字段字符集及排序规则

确实不是utf8_bin,接着看下该库里面表中字段的排序规则 ?...这要一个一个改,今晚估计回不了家了,单独修改库和修改表的字符集都比较简单,直接通过alter修改就可以,不同的是修改表的时候,还需要修改每个字段字符集,所以需要用CONVERT TO来修改,因为表名可以从...information_schema库中查到,所以想着,可以用concat拼接把表明拿到,可以获取到所有的alter命令,不需要自己再去一个一个改 具体步骤如下: 第一步,修改数据库编码及字符集 alter...第二步,获取所有修改表和字段的编码及字符集的命令 select concat("alter table `", TABLE_NAME,"` CONVERT TO CHARACTER SET utf8 COLLATE...接下来就简单了,将得到的命令执行就可以了,将上面的查询结果通过mysql -e或select info outfile导出为.sql文件之后,直接导入.sql文件即可 ?

5.3K20

MySQL 字符集

3.字符集级别 MySQL 支持多个不同级别的字符集设置,包括服务器级别、数据库级别、表级别、字段级别以及字符串常量级别。...WHERE TABLE_NAME = 'tbl_name'; 6.表字段字符集 每个 CHAR、VARCHAR、TEXT、ENUM、SET 类型的字段也可以拥有自己的字符集和排序规则。...CHARACTER SET 或者排序规则 COLLATE,MySQL 默认使用表的字符集和排序规则创建或者修改字段。...使用 SHOW CREATE TABLE 语句可以查看表中字段字符集和排序规则。 7.字符串常量字符集 另外,MySQL 中的字符串常量也有字符集和排序规则。...服务器在返回查询结果(包括字段名、字段值、错误信息等)之前需要将其转换为哪种字符集MySQL 使用 character_set_results 作为这种转换的目标字符集

21130

MySQL字符集

MySQL字符集 字符集介绍 gbk/gb2312 gbk/gb2312 采用双字节字符集,不论中、英文字符均使用双字符来表示,为了区分中文,将其最高位都设定成1 gb2312是gbk的子集,gbk...,好处就是节省空间,不推荐使用 MySQL字符集范围 服务器层(server) > 数据库成(database) > 数据表(table) > 字段(column) > 连接(connection) |...结果集(result) MySQL字符集优先级 连接(connection) | 结果集(result) > 字段(column) > 数据表(table) > 数据库成(database) > 服务器层...存储机制:varchar(N)字段存储实际是从第二个字节开始存储,然后用1到2个字节表示实际长度,剩下的才是可以存储数据的范围,因此最大可用存储范围是65535-3=65532字节;第一个字节标识是否为空...(长度小于255字节,使用一个字节来表示长度;大于255字节使用两个字节来表示长度) 修改数据库实例字符集 临时生效 mysql> set character_set = 'gbk'; mysql> set

3.6K10

字符集问题的初步探讨(七)----关于字符集更改的内部操作

原文链接: http://www.eygle.com/special/NLS_CHARACTER_SET_07.htm 前面我们提到,通过修改props$的方式更改字符集在Oracle7之后是一种极其危险的方式...我们又知道,通过ALTER DATABASE CHARACTER SET更改字符集虽然安全可靠,但是有严格的子集和超集的约束,实际上我们很少能够 用到这种方法。...实际上Oracle还存在另外一种更改字符集的方式....,把当前种子数据库的字符集更改为期望字符 集,这就是这条命令的作用....我们之前讲过的内容仍然有效,你可以使用csscan扫描整个数据库,如果在转换的字符集之间确认没有严重的数据损坏,或者你可以使用有效 的方式更改,你就可以使用这种方式进行转换.

80920

Mysql字符集-Mysql进阶(一)

上面提到的mysql连接,缓存,解析,优化都数据mysql service,他们都会调用各式各样的api来访问最后说的存储引擎。...2、字符集转成二进制叫编码,二进制转成字符集叫解码。...(所以在排序的时候,如果排序没有区分大小写或者有异常,可以看看他的比较级是什么) Mysql字符集的比较规则和字符集分为四个模块:服务器级别、数据库级别、表级别、列级别。...这上面有一个共同的特点,当修改了字符集,则自动变成当前字符集对应的比较级,如果修改了比较级,则自动变成对应的字符集。...Mysql字符集的转换 如果存入的是utf-8的编码,然后解析的是gbk的,这时候就会解码失败,于是我们看到的就是一堆乱码。

2.4K20

MySQL字符集详解

一、MySQL字符集编码简单介绍   在使用MySQL时要注意6个需要编码的地方:系统的编码、客户端、服务端、库、表、列。...字符集编码不仅影响数据存储,还影响client程序和数据库之间的交互.在mysql中输入命令show session variables like '%char%'能够看到例如以下一些字符集(下面是以win10...二、MySQL字符集编码层次   第一部分主要是归纳了MySQL文档中关于字符集编码的说明。这部分主要说明下MySQL字符集编码层次:服务端-->数据库-->表-->字段。   ...此外,mysql表中的字段也能够有自己的编码,假设不指定字段编码,则字段编码与表的编码一致....三、MySQL连接字符集   前面谈到的编码内容基本都不会产生乱码问题,mysql中容易产生乱码的地方在character_set_client, character_set_connection, character_set_results

3.3K10
领券