Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/arrays/12.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql 从给定具有列名的数组的另一个表中选择列_Sql_Arrays_Clickhouse - Fatal编程技术网

Sql 从给定具有列名的数组的另一个表中选择列

Sql 从给定具有列名的数组的另一个表中选择列,sql,arrays,clickhouse,Sql,Arrays,Clickhouse,假设我有这个表meta\u表 +------------+------------------------+ | table_name | col_names | +------------+------------------------+ | t1 | {ID, PRICE, OPERATION} | | t2 | {TYPE, PRICE, ANGLE} | +------------+---------------------

假设我有这个表
meta\u表

+------------+------------------------+
| table_name |       col_names        |
+------------+------------------------+
| t1         | {ID, PRICE, OPERATION} |
| t2         | {TYPE, PRICE, ANGLE}   |
+------------+------------------------+
其中col_name具有数组结构

t1
t2
具有数组中包含的列+数组中未显示的其他一些列

第一个问题:如何从表
t1
t2
中仅从列
列名称中选择数组中包含的列

第二个问题:主要目的是统计每个表的数组中每列的丢失数量,并将其返回到具有数组结构的新列中:

+------------+------------------------+-----------+
| table_name |       col_names        |  n_miss   |
+------------+------------------------+-----------+
| t1         | {ID, PRICE, OPERATION} | {0, 1, 0} |
| t2         | {TYPE, PRICE, ANGLE}   | {0, 0, 1} |
+------------+------------------------+-----------+
有什么办法吗

我用的是Clickhouse


非常感谢

这回答了问题的原始版本

如果我理解正确,您可以使用
数组联接
。我不太熟悉Clickhouse语法,但我认为这正是您想要的:

select a.*
from t1 array join
     t1.array as a;

该代码应该如何从t2中提取列?使用SQL是不可能的-您无法形成动态查询。使用服务器端解决此任务。谢谢vladimir,正如您所说,我没有找到方法来完成此任务,因此我最终导出了表并在R中完成了此任务