addValuePartitions添加分区时报错getSymbolConst method not supported

我的数据库是用下面的脚本创建的,按日期和品种进行值分区:

                DB_DIR="dfs://future";
                db1 = database(,VALUE, 2018.01.01..2019.12.31);
                db2 = database(,VALUE,`IC`IF) ;
                db = database(DB_DIR, COMPO, [db1, db2]);
                columns =`ID_`TaskID`JobID`TradingDay`ActionDay`Timestamp`UpdateTime`UpdateMillisec`InstrumentID`ProductID`ExchangeID`ExchangeInstID`LastPrice`PreSettlementPrice`PreClosePrice`PreOpenInterest`OpenPrice`HighestPrice`LowestPrice`Volume`Turnover`OpenInterest`ClosePrice`SettlementPrice`UpperLimitPrice`LowerLimitPrice`PreDelta`CurrDelta`BidPrice1`BidVolume1`AskPrice1`AskVolume1`BidPrice2`BidVolume2`AskPrice2`AskVolume2`BidPrice3`BidVolume3`AskPrice3`AskVolume3`BidPrice4`BidVolume4`AskPrice4`AskVolume4`BidPrice5`BidVolume5`AskPrice5`AskVolume5`AveragePrice
                columntypes  =[LONG,LONG,LONG,DATE,DATE,TIMESTAMP,SECOND,INT,SYMBOL,SYMBOL,SYMBOL,SYMBOL,DOUBLE,DOUBLE,DOUBLE,LONG,DOUBLE,DOUBLE,DOUBLE,LONG,DOUBLE,LONG,DOUBLE,DOUBLE,DOUBLE,DOUBLE,DOUBLE,DOUBLE,DOUBLE,LONG,DOUBLE,LONG,DOUBLE,LONG,DOUBLE,LONG,DOUBLE,LONG,DOUBLE,LONG,DOUBLE,LONG,DOUBLE,LONG,DOUBLE,LONG,DOUBLE,LONG ,DOUBLE]
             
                ticks = db.createPartitionedTable(table(100:0,columns,   columntypes),`ticks,`TradingDay`ProductID);

现在我想增加日期值分区,代码如下:

db=    database("dfs://future")            
addValuePartitions(db,2020.01.01..2020.01.10,0)

但执行后报错:
getSymbolConst method not supported
image.png

请问该如何增加分区?怎么知道分区有没有加成功,或怎么查看数据库已有哪些分区?

阅读 1.9k
1 个回答

这个错误是因为addValuePartitions的第3个参数值填错了。addValuePartitions语法如下:

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

其中level是分区所在的层,在您这里是日期维度分区所在的层,应该是0。

增加值分区的方法有2种(可参阅 https://www.dolphindb.cn/cn/h...):

 * 将配置参数newValuePartitionPolicy设定为add。在单机模式中,该参数在dolphindb.cfg中配置。在集群模式中,该参数在cluster.cfg中配置。
 * 使用addValuePartitions函数

建议在配置文件中配置newValuePartitionPolicy=add。

查看数据库已有哪些分区,可通过schema函数,例如:

db=    database("dfs://future")    
schema(db)

执行后显示如下:
image.png

日期分区太多,结果略写了,若要更详细的信息,可通过如下方式显示:

db=    database("dfs://future")    
schema(db).partitionSchema[0]    

执行后结果如下图:

image.png

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题