037、TiDB特性_管理DDL

  • DML不会阻塞其他会话DDL
  • 建议客户端应该处理异常:ERROR 8028(HY000)
  • 监控与取消操作
    • ADMIN SHOW DDL;
    • ADMIN SHOW DDL JOBS;
    • ADMIN SHOW DDL JOB QUERIES job_id;
    • ADMIN CANCEL DDL JOBS job_id;
/* source 07-demo-online-ddl-add-column-01-setup.sql */

/* target_table(id, name1) */
DROP TABLE IF EXISTS test.target_table;
CREATE TABLE test.target_table(
  id bigint PRIMARY KEY AUTO_RANDOM,
  name1 char(20));

/* Seed */
DROP TABLE IF EXISTS test.seed;
CREATE TABLE test.seed(name char(20));

insert into test.seed (name) values ('BEFORE-DDL'),('BEFORE-DDL'),('BEFORE-DDL'),('BEFORE-DDL'),('BEFORE-DDL');
insert into test.seed select * from test.seed;
insert into test.seed select * from test.seed;
insert into test.seed select * from test.seed;
insert into test.seed select * from test.seed;
insert into test.seed select * from test.seed;
insert into test.seed select * from test.seed;
select count(*) as "|320|" from test.seed;

DESC test.target_table;
/* source 07-demo-online-ddl-add-column-01-workload-before.sql */

/* Toggle autocommit with caution, you might create a very long TX. */
/* SET @@autocommit = 0; */
/* SET @@transaction_isolation='read-committed'; */
/* One Error is expected. */

BEGIN;
INSERT INTO test.target_table (id, name1) SELECT NULL, name FROM test.seed;
INSERT INTO test.target_table (id, name1) SELECT NULL, name FROM test.seed;
INSERT INTO test.target_table (id, name1) SELECT NULL, name FROM test.seed;
COMMIT;
SELECT name1 as "|NAME1|", count(*) as "|BEFORE-DDL-GOAL: 192000|" 
FROM test.target_table 
GROUP BY name1;
#!/bin/bash

# ./07-demo-online-ddl-add-column-01-workload-before.sh

mysql -h 127.0.0.1 -P 4000 -u root < 07-demo-online-ddl-add-column-01-setup.sql

sleep 5;

for i in $(seq 1 200); do
  mysql -h 127.0.0.1 -P 4000 -u root < 07-demo-online-ddl-add-column-01-workload-before.sql
done;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数哥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值