你能继续“开始”吗?雪花脚本中出现异常后的子句?

发布于 2025-01-14 11:43:20 字数 164 浏览 3 评论 0原文

在我的“开始”子句中,我使用循环来构建结果集并返回该结果集。理想情况下,当遇到异常时,我会在结果集中包含一条错误消息。但是,我在 Snowflake 脚本或 GOTO 语句中没有发现任何 try/catch 块的概念。我想我将不得不切换到 Snowflake 脚本和 Python、Javascript 等的混合。

In my "begin" clause I am using a loop to build a resultset and return that. Ideally I would include an error message in my resultset when I encounter an exception. However, I have not found any concept of a try/catch block in Snowflake scripting or a GOTO statement. I think I'm going to have to switch to a mix of Snowflake scripting and Python, Javascript, etc.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

厌倦 2025-01-21 11:43:20

BEGIN EXCEPTION END 块可以嵌套在 LOOP 内堵塞。伪代码:

BEGIN
   WHILE ... LOOP
     BEGIN
      ...
     EXCEPTION
         WHEN ... THEN ...
     END;

   END LOOP;
END;

The BEGIN EXCEPTION END block could be nested inside LOOP block. Pseudocode:

BEGIN
   WHILE ... LOOP
     BEGIN
      ...
     EXCEPTION
         WHEN ... THEN ...
     END;

   END LOOP;
END;
清晰传感 2025-01-21 11:43:20

一个简单的例子:

declare
  result varchar;
  my_exception exception (-20001, 'My custom exception.');
begin
  result := 'Success!';
  
  if (true) then
    raise my_exception;
  end if;
  
  return result;
exception
  when my_exception then
    return sqlerrm;
end;

-- returns "My custom exception."

Snowflake Scripting 中没有 GOTO 语法

A simple example:

declare
  result varchar;
  my_exception exception (-20001, 'My custom exception.');
begin
  result := 'Success!';
  
  if (true) then
    raise my_exception;
  end if;
  
  return result;
exception
  when my_exception then
    return sqlerrm;
end;

-- returns "My custom exception."

There is no GOTO syntax in Snowflake Scripting

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文