是否可以使用plpy.error/fatal传递自定义错误代码或继承SPIError以传递自定义ERRCODE、提示等?
发布于 2015-09-27 17:37:04
在查看plpython源代码时,我到目前为止发现的一种方法是继承SPIError并设置sqlstate。
raise type('MyError', (plpy.SPIError,), {'sqlstate': 'D000M'})(...)将传播ERRCODE D000M并为我工作。
一个很好的方法是定义一个自定义提示,但是看起来更棘手,因为它是随spidata而来的。
发布于 2015-09-27 16:41:46
我找到了一个解决办法。使用SPIError类的实例,并设置spidata属性。
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错误代码应该作为整数值输入,这是非常不友好的。我会看看如何更好地翻译它。
https://stackoverflow.com/questions/32795057
复制相似问题