是否可以传递自定义错误代码plpy.error/fatal
或继承SPIError
传递自定义 ERRCODE、HINT 等?
问问题
352 次
2 回答
2
在浏览 plpython 源代码时,我到目前为止发现的一种方法是从 SPIError 继承并设置sqlstate
raise type('MyError', (plpy.SPIError,), {'sqlstate': 'D000M'})(...)
将传播 ERRCODED000M
并为我工作。
一个很好的方法是定义一个自定义提示,但看起来更棘手,因为它带有spidata
.
于 2015-09-27T17:37:04.470 回答
1
我找到了解决方法。使用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
Errcode 应该输入为整数值,这是非常不友好的。我会看看如何更好地翻译它。
于 2015-09-27T16:41:46.123 回答