kdb - KDB - 当我将工作代码包装在函数中时出现错误
问题描述
我编写了以下从 sql 表中获取数据的函数。
get_sql_table:{[usr;psswd;server;db;tbl]
usr: "'", usr, "'";
psswd: "'", psswd, "'";
new_tbl: "'", tbl, "'\"";
map:(`date`datetime`bigint`char`decimal`double`int`varchar)!("DZJCFFIS");
schema:exec column_name!native from (update native:map[data_type] from (2#"S";enlist"\t") 0:
schema:system "mysql --user=",usr," --password=",psswd," -h ",server, " ", db, " --execute=\"select column_name, data_type from information_schema.columns WHERE table_name = ", new_tbl)
where not null native;
query: system "mysql --user=",usr," --password=",psswd," -h ",server, " ", db, " --execute=\"select * from ", tbl, ";\"";
data:(count["\t" vs query 0]#"S";enlist"\t") 0: query;
:![data;();0b;k!{($;schema[x];(string;x))} each k:key[schema] inter cols data];
};
当我加载脚本并尝试运行该函数时,有时会在最后一行(return 语句)出现类型错误。最后一行用于将适当的数据类型映射到 kdb 表。
但是,代码有时会成功。似乎它成功和失败的表是任意的,与列类型无关(实际上它在之前成功的表上失败了,反之亦然)。
此外,代码本身没有任何问题。当我在函数之外编写它时,它每次都有效,但表的数据类型不在 map 中(但在这种情况下,我可以将其添加到 map 中)。此代码仅在包装在函数中时才会失败。
我错过了什么?
解决方案
您的schema
变量是在函数中定义的,而不是全局定义的,因此无法从此 lambda 中访问它
{($;schema[x];(string;x))}
你必须像这样传递它
{($;y[x];(string;x))}[;schema] each k:key[schema] inter cols data
它可能在函数之外起作用,因为您不小心全局定义了schema
推荐阅读
- android - 在 Android 上的 Kotlin 中,如何在一个或每个循环期间在不可变列表中发生空指针异常?
- mysql - Mysql 按速度排序
- python - 使用 python 执行命令行脚本时找不到“__main__”模块
- java - Spring Webflux - 抛出检查的自定义异常(不是 RuntimeException)的正确方法
- java - 在 Postman 上测试时,GraphQL 查询语法错误。SpringBoot 服务器
- python - Seaborn 不断为多图翻转我的行
- javascript - 实时生成动态“视频”,输入数据?
- python - Python中的自定义聚合函数
- c++ - 当 BIO 不受套接字支持时,何时在使用诸如“SSL_connect()”之类的 OpenSSL 调用时正确刷新缓冲区?
- regex - Haskell 正则表达式的行为不同: