2.00.13

注: 同时建议阅读兼容性说明

版本下载

版本号:2.00.13 二级兼容 2.00.12

发行日期: 2024-06-30

下载地址:

新功能

  • 新增函数 getDBAccessgetTableAccess,能够查看拥有访问自己数据库和数据表权限的用户列表。(2.00.13.3
  • genOutputColumnsForOBSnapshotEngine 新增参数 residualDetail,用于指定输出剩余委托明细字段。同时 createOrderBookSnapshotEngine 支持输出剩余委托明细字段。(2.00.13.3
  • 函数 mcountmrank 新增参数 minPeriods,可规定滑动窗口中最少包含的观测值数据。(2.00.13.2
  • 新增函数 hmac,实现 HMAC(Hash-based Message Authentication Code)算法。(2.00.13.2
  • genOutputColumnsForOBSnapshotEngine 新增参数 seqDetail,用于指定输出序列号明细字段。同时 createOrderBookSnapshotEngine 支持输出序列号明细字段。(2.00.13.2
  • 新增函数 updateOrderBookEngineParams,用于在线设置 orderbookSnapshotEngine 的部分参数(通常是静态字段)值。(2.00.13.2
  • 新增函数 vectorNorm,用于计算矩阵/向量的范数。(2.00.13.2
  • 新增配置项 queryLogRetentionTime,用于设置节点查询日志文件的保留时间。(2.00.13.2
  • 新增 remoteRunCompatible 函数,功能与 remoteRun 相同。差别是此新增函数不对本地和远程数据库的版本进行验证。
  • scheduleJob 新增参数 priorityparallelism,用于设置定时任务的优先级和并行度。
  • saveText 新增参数 bom,可以在导出文件时指定是否输出 bom 头。
  • 新增 fminLBFGSB 函数,支持使用 L-BFGS-B 算法找到目标函数的最小值。
  • 新增 fminNCG 函数,支持使用牛顿共轭梯度法对目标函数进行无约束最小化。
  • 新增 fminBFGS 函数,支持使用 BFGS 算法找到目标函数的最小值。
  • 新增 fminSLSQP 函数,支持使用顺序最小二乘编程方法找到目标函数的最小值。
  • 新增 piecewiseLinFitpwlfPredict 函数,用于拟合分段线性回归函数和根据回归模型对数据进行预测。
  • 新增 brute 函数,用于通过穷举法在给定范围内最小化一个函数。
  • 新增 gaussianKdegaussianKdePredict 函数,用于使用核密度估计方法中的高斯核来估计随机变量的概率密度,和根据回归模型对数据进行预测。
  • 新增 vectorAR 函数,用于使用向量自回归模型来分析多变量时间序列。
  • 新增 eqPercent 函数,用于根据自定义约束条件,判断两个输入参数的每个对应位置上的元素是否都相等。
  • 新增配置项 batchJobFileRetentionTime,用于设置批处理作业和定时任务执行后输出信息的最长保留时间。
  • 新增配置项 resourceSamplingLogDir,用于设置资源跟踪日志的存储路径。
  • 支持三元运算符(? :)。
  • 新增配置项 jobLogRetentionTime, 用于设置数据节点上查询信息日志的最长保留时间。
  • 新增 removeNode 函数,以支持动态删除计算节点。同时支持通过 addNode 一次添加多个节点。
  • 支持 chimp 压缩算法。
  • 新增函数 setTableComment,用于为分布式表添加表注释。同时 create 语句新增参数 comment,可在创建分布式表时添加表注释。
  • 新增配置项 TSDBSymbolBaseEvictTimeTSDBCachedSymbolBaseCapacity,可以根据缓存时间或缓存容量来决定何时逐出未被使用的 symbolBase 数据。同时新增函数 clearAllTSDBSymbolBaseCache,用于清除缓存中所有未被使用的 symbolBase。
  • SQL DELETE 语句和 sqlDelete 函数支持通过 join 来指定删除行。
  • 新增函数 setTableComment,用于为分布式表添加注释。同时 create 语句中新增参数 comment
  • 新增配置项 memLimitOfAllTempResults,用于设置分布式查询操作中产生的所有临时表可以占用的内存上限。同时新增了与其对应的函数 setMemLimitOfAllTempResultsgetMemLimitOfAllTempResults 分别用于动态设置和获取配置项。
  • 新增配置项 enableInsertStatementForDFSTable,用于设置是否允许 insert into 语句插入 DFS 表。
  • insert into 支持插入多行数据。

功能优化

  • 优化了当消费速度较慢时的内存占用。(2.00.13.9
  • 在同时满足以下条件时,优化 createTimeSeriesEngine 函数的内存占用:(2.00.13.8
    • windowSize 仅设置为标量。
    • windowSizestep 取值相同。
    • acceptedDelay > 0。
    • useSystemTime = false。
    • keyColumn 非空。
  • 当已有分区数量达到百万级以上时,提升创建新分区的性能。(2.00.13.7
  • 优化异步复制的日志打印信息。(2.00.13.7
  • 优化时序聚合引擎功能:当设置 useSystemTime=false 时, acceptedDelay 可以大于 windowSize。(2.00.13.6
  • 优化了当消费速度较慢时的内存占用。(2.00.13.6
  • 权限 QUERY_RESULT_MEM_LIMIT 和TASK_GROUP_MEM_LIMIT 支持对组进行管理。(2.00.13.5
  • 内存管理器由 tcmalloc_minimal 替换为 tcmalloc,同时新增函数 startHeapSample, dumpHeapSample, stopHeapSample 以支持堆内存采样。(2.00.13.5
  • createOrderBookSnapshotEngine 函数设置 useSystemTime = true 时,支持设置 skipCrossedMarket = false。(2.00.13.5
  • stringFormat 指定占位符是 %X 时,支持 输入长整型数据。(2.00.13.5
  • flatten 函数新增参数 depthFirst,支持设置展开算法。(2.00.13.5
  • X 是非负整数/一元函数/空值时,若 func 是多元函数且仅有一个必填参数函数 ,accumulate/reduce 函数将 func 视为一元函数。(2.00.13.5
  • 响应式状态引擎的状态函数 percentChangedeltas 允许将参数 n 指定为正整数。(2.00.13.4
  • 增强 loadPlugin 函数功能,以支持插件市场的付费插件。(2.00.13.3
  • 优化createOrderBookSnapshotEngine 函数在设置 useSystemTime = true 时的以下功能:
    • 每隔 intervalInMilli 输出一次数据。(2.00.13.3
    • 休盘时段 (11:30:00.000,13:00:00.000] 不输出数据。(2.00.13.3
  • 优化持久化流表的加载速度。(2.00.13.3
  • 分区方案使用时间类型时,对分区列的类型增加校验。(2.00.13.3
  • 优化登录失败保护机制,即仅在登录失败的 IP 地址上锁定用户登录。(2.00.13.2
  • 若 TSDB 引擎的去重设置为保留所有数据,则通过upsert! 更新数据时,支持 keyColNames 仅指定 sortColumns 的部分列。(2.00.13.2
  • backup 等相关操作支持记录 tableOwner 信息。同时restore 等相关操作支持恢复 databaseOwner 和 tableOwner 信息。(2.00.13.2
  • 优化 orderbookSnapshotEngine 的以下功能:
    • 优化合成逻辑,已停牌的标的数据将不会合成输出。(2.00.13.2
  • 增强权限管理等功能,以提高系统安全性。(2.00.13.1
  • 优化 interval 函数的以下功能:
    • duration 参数支持交易日历。
    • 当参数 durationstep 长度不同时, 在对非分区表的查询中可以对查询列应用自定义聚合函数。
  • flatten 函数支持元组嵌套。
  • logisticRegression 函数精度与 SKLearn 中相应函数对齐。
  • 提高函数 std, stdp, var, varp, skew, kurtosis 的精度。
  • 高阶函数 moving 的参数 func 支持返回 tuple 的函数。
  • addMetrics 新增支持 fill 参数,可以指定对空值处理方法。
  • parseJsonTable 函数支持传入的表中包含 BLOB 类型的列。
  • isDuplicated 函数支持 BLOB 类型。
  • fmin 函数优化输入参数。
  • rowAlign 函数支持列式元组。
  • rolling 函数支持显示行标签。
  • 元编程中的列别名支持使用宏变量。
  • registerSnapshotEngine 函数新增参数 dedupColumnName,以支持在集群中所有数据节点上为分布式表注册快照引擎。
  • 模式符号可以搭配系统内置,作为一个运算符。
  • restore 函数的 snapshot 参数的默认值由 true 修改为 false。
  • 异步复制中从集群中不再需要通过clusterReplicationExecutionPassword 配置密码,以提高安全性。
  • 提升 TSDB redolog 回放性能。
  • version 函数支持返回更多版本信息。
  • clearAllCache 新增支持清理 TSDB 引擎相关的缓存。
  • TSDB 数据写入时可以压缩空值列。
  • createSchema 不支持将数据库同时加到两个 catalog 中。
  • 优化订单簿引擎的以下功能:
    • 报错日志等级修改为 WARNING。
    • createOrderBookSnapshotEngine 新增参数 useSystemTime,支持使用系统时间来触发快照输出。
  • 优化响应式状态引擎的以下功能:
    • 支持对 array vector 列使用 prev 函数。
    • 优化报错信息。
    • 新增支持 35 个 topN 状态函数。
    • keyColumn 由必填参数修改为可选参数。
    • 自定义状态函数中赋值语句的右值支持返回多个值的自定义函数。
  • createLookupJoinEngine 的参数 rightTable 支持指定为元代码。
  • 如下流计算引擎的 metrics 支持指定为常数标量或向量:createReactiveStateEngine, createAsofJoinEnginecreateLookupJoinEnginecreateEquiJoinEnginecreateLeftSemiJoinEngine
  • enableTablePersistenceenableTableShareAndPersistence 函数新增参数 cachepurgeTimeColumn, cachePurgeInterval, cacheRetentionTime,用于设置持久化流表在内存中的数据清理策略。
  • createTimeSeriesEnginecreateDailyTimeSeriesEngineacceptedDelay 参数支持根据数据时间来设置关闭窗口的延时。
  • 如下流计算引擎新增支持 outputHandler, msgAsTable 参数,支持输出结果到一个一元函数:createTimeSeriesEngine, createDailyTimeSeriesEngine, createReactiveStateEngine, createDualOwnershipReactiveStateEngine, createNarrowReactiveStateEngine
  • 优化 SQL JOIN 的以下功能:
    • INNER JOIN 和 LEFT JOIN 支持生成 IN 谓词的 动态过滤条件(Runtime Filter),以提升查询性能。
    • 提升对分区字段进行过滤,同时搭配 LIMIT 字段时的查询性能。
    • CASE WHEN 语句支持分析函数 OVER(PARTITION BY xxx)。
  • 优化 JIT 高阶函数 accumulatereduce
  • JIT 支持处理索引矩阵。

故障修复

  • 当 TSDB 引擎写入的 DECIMAL 数据精度超过表结构设置的精度时,重启集群进行回放会发生错误。(2.00.13.9
  • 向键值内存表中插入表数据时,若插入的列和键值内存表键值列的类型不一致,且无法进行类型转换时,将导致 server 崩溃。此为 2.00.11.1/1.30.23.1引入的问题。(2.00.13.9
  • 修复 createCrossSectionalEngine(横截面引擎)的以下问题(2.00.13.9):
    • metrics 中指定的别名数量少于返回的列数,导致服务器崩溃。
    • 同时指定 contextByColumnkeyFilter 时,keyFilter 指定的函数会被调用两次。
  • 在 asof join 引擎中,timeColumn 同时指定了左表和右表中的时间列,metrics 中仅指定右表时间列时,后台出现报错。(2.00.13.9
  • 当流计算引擎的输出表指定为共享表的别名时,如果发生并发写入共享表,server 偶发崩溃。(2.00.13.9
  • 在表连接操作中,偶发由于系统修改子查询中的变量名而导致找不到列名的错误。(2.00.13.9
  • 当 pivot by 指定的最后一列为分区字段时,若查询的数据量过大,则会报错。(2.00.13.9
  • createTimeSeriesEnginemetrics 参数指定为返回多个值的自定义聚合函数,同时设置parallelism 大于 1 会导致计算结果错误。(2.00.13.8
  • TSDB 引擎设置 keepDuplicates=FIRST 时,在高并发场景下偶发去重失效。(2.00.13.5
  • 在线修改高可用集群配置,leader 切换后修改失效。(2.00.13.5
  • 在通过 submitJob 并发执行由 sqlDS 生成的任务时,可能会导致服务器崩溃。(2.00.13.5
  • 配置 enhancedSecurityVerification=true 后,并发登录可能导致 server 小概率崩溃。这是 2.00.11 引入的问题。(2.00.13.5
  • 在对流数据表进行过滤后,如果数据剩余不多,可能会导致发布数据变慢。(2.00.13.5
  • getStreamEngineStat 返回的结果中, orderbookSnapshotEngine 的 numGroups 值有误。(2.00.13.5
  • createTimeSeriesEnginecreateDailyTimeSeriesEngine 在指定 acceptedDelay 的值为窗口长度(windowSize) 时,会自动插值。(2.00.13.5
  • 日级时序聚合引擎在接收到乱序时间后,会导致日期列填充了”invalid date”。(2.00.13.5
  • 对 DECIMAL 类型数据执行 segmentby ,结果丢失精度。(2.00.13.5
  • 函数视图中包含 insert into 语句导致server 启动失败。(2.00.13.5
  • dropTable 删除表后,通过 renameTable 修改该表的表名, 若此操作与 checkpoint 并发执行,可能导致丢失元数据。(2.00.13.5
  • Windows JIT 版本偶发卡住。(2.00.13.5
  • [D20-18889] 在订阅流表时,偶尔因数据乱码而导致订阅失败。(2.00.13.4
  • [D20-19049] 修改 flatten 函数以兼容之前版本。(2.00.13.4
  • [D20-18167] 开启资源跟踪后,可能导致 server 崩溃。(2.00.13.3
  • [D20-18430] 表连接时,若表里包含的数组向量中的元素超出长度限制时,导致 server 崩溃。(2.00.13.3
  • [D20-18483] 操作 MVCC 表发生事务异常时,未正确清理状态。(2.00.13.3
  • [D20-18484] createReactiveStateEngine 在未设置 keyColumnoutputHandler 不为 null 时, 无法触发 outputHandler。(2.00.13.3
  • [D20-18522] moveHotDataToColdVolume 在对相同分区进行并发转移时,发生数据丢失。(2.00.13.3
  • [D20-18540] 作业开始时,如果磁盘被占满,则不能正确记录作业信息,如开始时间。(2.00.13.3
  • [D20-18553] 在高可用集群中,当 controller 发生重启,若 checkpoint 失败,可能导致元数据丢失。(2.00.13.3
  • [D20-18603] rollingPanel 在指定 groupingCol 参数时,未进行分组。(2.00.13.3
  • [D20-18640] 若 submitJobscheduleJob 中的任务包含 lambda 函数,当创建它们的 session 断开后,可能导致 server 崩溃。(2.00.13.3
  • [D20-18661] 当 SQL 查询中使用到 vectorized grouping 算法时,若聚合函数的某个参数是标量或大小与输入表不匹配的向量时,可能导致结果错误。(2.00.13.3
  • [D20-18697] 修改flatten 函数以兼容之前版本。(2.00.13.3
  • [D20-18703] 在对分布式表进行 EXEC 查询时,如果指定了 ORDER BY 和 LIMIT/TOP(设置为正数),且 ORDER BY 仅涉及一个分区列且采用降序排序,引发错误:“The result of distributed call is not a table”。(2.00.13.3
  • [D20-18723] createDailyTimeSeriesEngine 在经过 forceTriggerSessionEnd 时间后,若接收到时间戳小于 sessionEnd 的数据,可能输出非预期的结果。(2.00.13.3
  • [D20-18780] 若异步复制任务中存在数据损坏,系统无法跳过该任务而持续重试。(2.00.13.3
  • [D20-18790] 使用 order by 和 limit/top 进行分布式查询优化时,在执行最终查询时找不到所需的列。(2.00.13.3
  • [D20-18827] 通过 parseJsonTable 解析 JSON 对象时,若 JSON 对象的字符串中包含 \\\" 时,会导致解析错误或报错(2.00.13.3
  • [D20-18152] 某个最大优先级或并行度小于默认值的用户通过 Web 或 VS Code 提交前台任务,该任务的优先级或并行度仍为默认值。(2.00.13.2
  • [D20-18162] 审计日志中 APPEND 操作的开始日期记录错误。(2.00.13.2
  • [D20-18195] 上传加密模块可能导致当前会话中的变量丢失。(2.00.13.2
  • [D20-18245] 执行 backup 函数时,如果过滤条件是组合分区的一级分区,而二级分区中的部分分区没有数据,则会导致报错。(2.00.13.2
  • [D20-18272] 重启后定时任务中执行 writeLogLevel 函数报错。(2.00.13.2
  • [D20-18312] 对 arrayVector 类型的列查询 distinct 导致 server 崩溃。(2.00.13.2
  • [D20-18356] 在执行 ej 操作时,若 where 条件中不指定表名则无法查询数据。(2.00.13.2
  • [D20-18328] orderBookSnapshotEngine 在设置 useSystemTime = true 时偶现部分输出数据被遗漏。(2.00.13.2
  • [D20-18423] 执行传入不合规参数的createWindowJoinEngine 函数后宕机。(2.00.13.2
  • [D20-18122] 使用 move 函数时,若传入参数 X 是临时变量可能导致计算结果错误。(2.00.13.2
  • [D20-18219] 多次执行 mpercentile 函数偶现宕机。(2.00.13.2
  • [D20-18331] JIT 中使用 rank 函数时由于类型推导问题报错。(2.00.13.2
  • [D20-18291] JIT 中使用 isort 函数时由于兼容性问题报错。(2.00.13.2
  • qclp 函数计算目标函数时,返回非预期结果。
  • saveText 函数传入字符串对象引起宕机。
  • 同时使用 ateachRighteachLeft 时宕机。
  • 使用 loadText 加载文件太大(一行数据超过 2 GB)引起宕机。
  • 继承 class 时使用 dict 函数无法被识别。
  • 函数 getUserHardwareUsage 因内部计算错误导致参数设为日期时不生效。
  • 函数 getSlaveReplicationQueueStatus 返回值中的 executionSet 字段偶现随机值。
  • getQueryStatus 函数返回值中的 startTime 未进行时区转换。
  • loadText 函数将符合某些条件的字符串误识别为 DATE 类型,导致无法加载数据。
  • 将模块或插件中没有返回值的函数添加为functionView 失败。
  • ARM 环境中使用 OpenBLAS 进行多线程计算引发宕机。
  • 键值内存表更新 array vector 数据时,出现报错。
  • windows join 中指定聚合函数为 count(head()) 导致 server 崩溃。
  • SQL 语句同时满足以下条件:包含 group by 子句,from 子句为一个空表,select 子句中包含自定义变量时,会出现解析错误。
  • pj 连接时,若左右表按连接列排序,对于左表某行,只选取右表中的第一个连续匹配的行数据,导致结果中缺少数据。
  • 在 join 查询中,如果指定的连接列的列名与表中实际的列名大小写不一致,会导致执行计划未被优化。
  • WHERE 子句中 IN 的右值为内存表时,没有分区剪枝。