登录
首页 >  Golang >  Go问答

使用 Go 调用 Snowflake 存储过程

来源:stackoverflow

时间:2024-02-16 15:45:22 501浏览 收藏

小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《使用 Go 调用 Snowflake 存储过程》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

问题内容

我在 snowflake 中有一个名为 sp_merge_assets 的存储过程。我可以通过执行以下操作从 snowflake 控制台调用它:

call my_database.my_schema.sp_merge_assets(0)

这有效并且完全符合我的预期。然而,当我尝试从 snowflake 的 go 库中执行完全相同的过程时:

query := "CALL MY_DATABASE.MY_SCHEMA.sp_merge_assets(?)"
_, err := client.db.ExecContext(ctx, query, 0)

我收到 sql 编译错误,指出 unknown 用户定义函数 my_database.my_schema.sp_merge_assets

我认为这是有道理的,因为我的帐户中没有定义名为“my_database.my_schema.sp_merge_assets”的 udf。但这个错误掩盖了实际的问题:我的存储过程没有被调用。我在这里做错了什么?


正确答案


事实证明,与 sql server 不同,在 snowflake 中调用存储过程需要使用 querycontext 函数而不是 execcontext 函数。如果您使用 execcontext,snwoflake 会将查询解释为对用户定义函数的调用。将代码更改为

query := "CALL MY_DATABASE.MY_SCHEMA.sp_merge_assets(?)"
_, err := client.db.QueryContext(ctx, query, 0)

解决了问题。

理论要掌握,实操不能落!以上关于《使用 Go 调用 Snowflake 存储过程》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>