mysql在线ddl实例,mysql 在线DDL操作之手动处理

案例1,将book表的book_name字段字符长度30改为40

表结构如下

CREATE TABLE `test`.`book` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`user_id` int(11) NULL DEFAULT NULL,

`book_name` char(30) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,

PRIMARY KEY (`id`) USING BTREE,

INDEX `index_user_id`(`user_id`) USING BTREE

) ENGINE = InnoDB AUTO_INCREMENT = 187018 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

具体操作步骤如下

1、创建临时表作为修改之后的表

create table book_tmp like book; 然后再基础上修改,或者直接创建

CREATE TABLE `test`.`book_tmp` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`user_id` int(11) NULL DEFAULT NULL,

`book_name` char(40) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,

PRIMARY KEY (`id`) USING BTREE,

INDEX `index_user_id`(`user_id`) USING BTREE

) ENGINE = InnoDB AUTO_INCREMENT = 187018 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

2、给原表加上读锁,保证之后不会再对原表有任何的数据修改

flush table WITH read lock; (这个操作会给所有表加读锁!)

0cdc671adfcf

image.png

3、将book表的frm文件用book_tmp表的frm文件覆盖

注意以防万一,现备份好原来的frm文件!

4、 刷新表结构,之后修改就生效了

FLUSH tables;

5、最后别忘了解锁

unlock tables;

案例2,将book表的book_name字段的数据类型从char改为tinytext

依葫芦画瓢,替换frm和fluash表后直接让mysql宕机了!因此种方法对于修改列数据类型是无效的!

案例3,将char修改为varchar

可以,但是修改后的值会出现多余类似空格的字符!

这种方式局限性很大,最好不要使用。会出现一些意想不到的问题。推荐使用工具pt-online-schema-change 来完成在线DDL。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值