addValuePartitions

语法

addValuePartitions(dbHandle, newValues, [level=0], [locations])

参数

dbHandle 是数据库句柄。

newValues 是标量或向量,表示新的分区。

level 是整数。当分区类型为COMPO,并且每层分区为VALUE时,需要使用level参数指定VALUE分区所在的层。它是可选参数。默认值为0

locations 是字符串标量或向量。如果目标数据库创建时,指定了locations参数,增加新的分区时可以使用locations参数指定新增分区的位置。它是可选参数。

详情

给数据库增加新的分区。目标数据库必须是VALUE分区类型或COMPO分区类型并且至少其中一层分区为VALUE类型。

如果配置参数newValuePartitionPolicy=add,系统会自动为新的数据增加分区。详情请参考单实例配置。

例子

下面的例子是给分区类型为COMPO的数据库新增2017.08.12到2017.08.20分区。

$ n=1000000
$ ID=rand(100, n)
$ dates=2017.08.07..2017.08.11
$ date=rand(dates, n)
$ x=rand(10.0, n)
$ t=table(ID, date, x)

$ dbID=database(, RANGE, 0 50 100);
$ dbDate = database(, VALUE, 2017.08.07..2017.08.11)
$ db = database("dfs://compoDB", COMPO, [dbID, dbDate]);
$ pt = db.createPartitionedTable(t, `pt, `ID`date)
$ pt.append!(t)

$ addValuePartitions(db,2017.08.12..2017.08.20,1)
9

添加新的分区后,需要重新加载数据库。

$ db=database("dfs://compoDB")
$ pt=loadTable(db,"pt")

$ t1=table(0..99 as ID,take(2017.08.12,100) as date,rand(10.0,100) as x)
$ pt.append!(t1)

$ select count(*) from loadTable("dfs://compoDB","pt")
1000100