首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用plpy.error或自定义SPIError传递自定义错误代码(ERRCODE)

使用plpy.error或自定义SPIError传递自定义错误代码(ERRCODE)
EN

Stack Overflow用户
提问于 2015-09-26 08:15:08
回答 2查看 394关注 0票数 2

是否可以使用plpy.error/fatal传递自定义错误代码或继承SPIError以传递自定义ERRCODE、提示等?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-09-27 17:37:04

在查看plpython源代码时,我到目前为止发现的一种方法是继承SPIError并设置sqlstate

代码语言:javascript
复制
raise type('MyError', (plpy.SPIError,), {'sqlstate': 'D000M'})(...)

将传播ERRCODE D000M并为我工作。

一个很好的方法是定义一个自定义提示,但是看起来更棘手,因为它是随spidata而来的。

票数 2
EN

Stack Overflow用户

发布于 2015-09-27 16:41:46

我找到了一个解决办法。使用SPIError类的实例,并设置spidata属性。

代码语言:javascript
复制
postgres=# do $$
x = plpy.SPIError('Nazdarek'); 
x.spidata = (0, "Some detail", "some hint", None, -1); 
raise x;
$$ language plpythonu;

ERROR:  plpy.SPIError: Nazdarek
DETAIL:  Some detail
HINT:  some hint
CONTEXT:  Traceback (most recent call last):
  PL/Python anonymous code block, line 4, in <module>
    raise x;
PL/Python anonymous code block

错误代码应该作为整数值输入,这是非常不友好的。我会看看如何更好地翻译它。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32795057

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档