概述
分布式中LSC表不支持修改字段,本文通过间接的方案快速实现LSC表字段的修改。
LSC表修改列方案
假如原表如下,将字段area_name长度由VARCHAR2(60)修改为VARCHAR2(100)
CREATE TABLE area
(area_no CHAR(2) NOT NULL PRIMARY KEY,
area_name VARCHAR2(60),
DHQ VARCHAR2(20) DEFAULT 'ShenZhen' NOT NULL);
修改步骤如下
|
-- 注:以下SQL需在yasql命令行下执行 -- step1:将原表备份 ALTER TABLE area RENAME TO area_bak; -- step2:统计备份表记录数 SELECT COUNT(*) FROM area_bak; -- step3:重建表,将字段area_name长度由VARCHAR2(60)修改为VARCHAR2(100) CREATE TABLE area (area_no CHAR(2) NOT NULL PRIMARY KEY, area_name VARCHAR2(100), DHQ VARCHAR2(20) DEFAULT 'ShenZhen' NOT NULL); -- step4:将备份表数据通过bulkload冷数据方式快速导入新表 SET AUTOCOMMIT OFF; INSERT /*+ bulkload */ INTO area select * from area_bak; COMMIT; -- step5:统计新记录数 SELECT COUNT(*) FROM area; -- step6:确保新表记录数没问题,删除备份表 DROP TABLE area_bak; |
1106

被折叠的 条评论
为什么被折叠?



