这个问题有帮助:https ://community.denodo.com/answers/question/details?questionId=90670000000CcQPAA0
我通过创建一个将数组保存为字段的视图来使其工作:
CREATE OR REPLACE VIEW p_sample_data FOLDER = '/stack_overflow'
AS SELECT bv_sample_data.location AS location
, bv_sample_data.id AS id
, split('-', location) AS location_array
FROM bv_sample_data;
请注意,我创建了一个名为location_array
?
现在您可以在视图顶部使用 select 语句来提取您想要的信息:
SELECT location, id, location_array[2].string
FROM p_sample_data
location_array[2]
是第三个元素,它.string
告诉 denodo 你想要字符串值(我认为这就是它的作用......你必须在文档中阅读更多关于复合值的信息:https ://community.denodo.com/docs/ html/browse/6.0/vdp/vql/advanced_characteristics/management_of_compound_values/management_of_compound_values)
您可能会这样做的另一种方法是使用数组创建一个视图,然后展平数组,尽管我没有尝试过该选项。
更新:我尝试创建一个展平数组的视图,然后使用分析(或“窗口”)函数来获取row_number() OVER (PARTITION BY id order by ID ASC)
,但分析/窗口函数不适用于平面文件源。
因此,如果您采用“扁平化”路线并且您的源系统不适用于分析功能,您可以直接使用 rownum() 函数,但您必须通过您想要的列号偏移该值,然后使用余数除法来提取你想要的数据。
像这样:
--My view with the array is called p_sample_data
CREATE OR REPLACE VIEW f_p_sample_data FOLDER = '/stack_overflow' AS
SELECT location AS location
, id AS id
, string AS string
, rownum(2) AS rownumber
FROM FLATTEN p_sample_data AS v ( v.location_array);
现在,使用 rownum() 函数(偏移量为 2),我可以在 where 子句中使用余数除法来获取我想要的数据:
SELECT location, id, string, rownumber
FROM f_p_sample_data
WHERE rownumber % 5 = 0
坦率地说,我认为更简单的方法是将您的位置数据留在数组中并使用location_array[2].string
语法提取第 n 列,其中2
第 n 列是从零开始的。