首页 > 解决方案 > 从 Snwoflake 表的变量列中获取 xml 元素

问题描述

这是我的样本数据

ID  VERSION ACT_TYPE    EVE_TYPE    CLI_ID  DETAILS OBJ_TYPE    DATE_TIME   AAPP_EVENT_TO_UTC_DT    GRO_ID  OBJECT_NAME OBJ_ID  USER_NAME   USER_ID EVENT_ID    FINDINGS    SUMMARY

6tgbcrq9pfhj1ezsdo82mcrzz   o   SCREENED_CASE   WORLDCHECK  o   <?xml version="1.0" encoding="UTF-8" standalone="yes"?><testPayload><testId>565656-21cf-4c7e-8071-574a1ef78981</testId><testCode>COMPLETED</testCode><testState>TEST</testState><testResults>1</testResults><testRequiredResults>0</testRequiredResults><testExcludedResults>0</testExcludedResults><testAutoResolvedResults>1</testAutoResolvedResults><testproviderTypes>WATCHLIST</testproviderTypes></testPayload>  CASE    9/16/2020 9:45  9/16/2020 9:45  erutrt7-d726-4672-8599-83d21927bec5 o   5786765dfgdfgdfg    System User USER_SYSTEM o   o   <?xml version="1.0" encoding="UTF-8" standalone="yes"?><testCaseEventSummary><testTypes>WATCHLIST</testTypes><testResults>1</testResults></testCaseEventSummary>

我需要从这个表中获取 ID、testId。

请注意 testId 在 DETAIL 列内,它是一个 xml 。

我正在尝试类似下面的东西,但它不起作用

select DETAILS:"$" from  audit_event;

标签: snowflake-cloud-data-platform

解决方案


首先,您需要使用 parse_xml 将其转换为 xml,然后使用xmlget函数获取 testId 字段,如下所示:

select xmlget(parse_xml(details), 'testId'):"$"::varchar from audit_event

我以为你想要它回来,varchar所以我把它放在::varchar最后。


推荐阅读