snowflake-cloud-data-platform - 雪花合并对象/json
问题描述
有什么方法可以合并雪花中的 2 个对象吗?我找到了https://docs.snowflake.net/manuals/sql-reference/functions/object_insert.html,但一次只能设置/更新一个键。我想合并 2 个对象(类似于Object.assign()
js 中的东西)。还试图通过从该数组转换为数组、连接和构造对象来找到解决方法,但未能使其工作。
谢谢!
解决方案
Snowflake 没有这样的内置函数,但是Object.assign()
在 Snowflake 的JavaScript UDF中使用它很简单:)
create or replace function my_object_assign(o1 VARIANT, o2 VARIANT)
returns VARIANT
language javascript
as 'return Object.assign(O1, O2);';
select my_object_assign(parse_json('{"a":1,"b":2,"c":3}'), parse_json('{"c":4, "d":5}')) as res;
-----------+
RES |
-----------+
{ |
"a": 1, |
"b": 2, |
"c": 4, |
"d": 5 |
} |
-----------+
推荐阅读
- go - 如何使用 API 平滑光栅化 PDF?
- javascript - 如何在移动设备上发送推送通知(Android Crome)PWA
- spring - 没有找到能够从 [java.lang.String] 类型转换为 [java.util.LinkedHashMap] 类型的转换器
] - laravel - 使用哪种授权类型来验证第三方客户端的 API 访问权限?
- magento - 单个商店的 Magento 多个动态自定义路由
- c# - 没有 BlockingCollection 的简单生产者-消费者集合
- maven - 交互模式下的 Maven 配置文件激活
- php - 为什么 Symfony 3.4 在 PHP 通知中抛出 ContextErrorException 而 Symfony 2.8 在相同的代码上运行良好?
- android - 安卓谷歌登录
- microsoft-graph-api - Microsoft Graph API 获取 Outlook 日历事件不起作用