1、新增分片
ALTER FRAGMENT ON TABLE frag_tab1 ADD sale_time < '2011-06-01 00:00:00' AND sale_time>= '2011-05-01 00:00:00' IN datadbs05 BEFORE datadbs04;
ALTER FRAGMENT ON TABLE orders ADD note_code > 3000 IN dbspace4;
2、删除分片
ALTER FRAGMENT ON TABLE table1 DROP dbspace1;
ALTER FRAGMENT ON TABLE table1 DROP PARTITION part1;
ALTER FRAGMENT ON INDEX table1_idx1 DROP dbspace4;
3、ALTER FRAGMENT ... ATTACH 用来将一个表作为一个分片合并到分片表中
ALTER FRAGMENT ON TABLE frag_tab1 ATTACH tab_May as (sale_time<'2011-06-01 00:00:00' AND sale_time>='2011-05-01 00:00:00') before datadbs04;
ALTER FRAGMENT ON TABLE table1 ATTACH table1, table2;
4、ALTER FRAGMENT ...DETTACH操作将分片表的一个分片卸载到一个表中
ALTER FRAGMENT ON TABLE frag_tab1 DETACH datadbs01 tab_Jan ;
ALTER FRAGMENT ON TABLE table1 DETACH dbspace2 table2;
ALTER FRAGMENT ON TABLE table1 DETACH PARTITION part1 table2;
5、初始化分片表
ALTER FRAGMENT ON TABLE table1 INIT IN dbspace2;
ALTER FRAGMENT ON TABLE table1 INIT FRAGMENT BY ROUND ROBIN IN dbspace1, dbspace2;
ALTER FRAGMENT ON TABLE table1 INIT FRAGMENT BY EXPRESSION col_1 <= 10000 AND col_1 >= 1 IN dbspace1,
col_1 <= 20000 AND col_1 > 10000 IN dbspace2;
6、修改分区
ALTER FRAGMENT ON TABLE table1 MODIFY dbspace1 TO col_1 > 30000 IN dbspace1;
ALTER FRAGMENT ON TABLE table1 MODIFY part1 TO PARTITION part1 col_1 > 30000 IN dbspace1;
ALTER FRAGMENT ON TABLE table1 MODIFY dbspace3 TO REMAINDER IN dbspace5;
关于ROWID
Informix 表有一个隐含的属性rowid,用来标记记录的物理存储位置,rowid 是Informix 内部使用的一个序号。而对于分片表不再有这样的rowid,如果应用程序使用了rowid,可以给分片表增加一个rowid 字段,对于分片表rowid 只是一个Infromix 自动创建的serial 类型的一个字段,需要额外的存储空间。Rowid 的值在所有的分片都是不重复的。同时为该字段创建一个索引来指向记录row的物理存储地址。
alter table frag_tab1 add rowids; 增加ROWID
alter table items DROP ROWIDS;
CREATE TABLE orders(
order_num SERIAL,
customer_num INTEGER,
part_num CHAR(20))
WITH ROWIDS
FRAGMENT BY ROUND ROBIN IN dbs1,dbs2;
FORCE_DDL_EXEC
当我们执行ALTER FRAGMENT ON TABLE ….ATTACH/DETACH/ADD/DORP等操作时,需要独占表,但是在我们的7X24 运行的OLTP 系统中,表时时刻刻被访问,如果我们需要强行执行分片管理操作的,常遇到锁的问题,对DBA 而言非常的麻烦。从Informix11.5 FC6 版本后提供环境标量FORCE_DDL_EXEC,可以强行抢占锁来执行分片管理命令。同时把正在执行的其他事务踢出并提示长事务错误(-458 Long transaction aborted.)。
SET ENVIRONMENT FORCE_DDL_EXEC 'on';
alter fragment on table test_attach_dettach_fragment detach dbs11 tmp_dbs11;
alter fragment on table test_attach_dettach_fragment add c1=1 in dbs11;
DATASKIP的使用和禁用:
SET DATASKIP ON;
SET DATASKIP OFF;
SET DATASKIP ON dbspace1;