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

时间:2015-09-26 08:15:09

标签: postgresql plpgsql plpython

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

2 个答案:

答案 0 :(得分:2)

在浏览plpython源代码时,我发现的一种方法是继承SPIError并设置sqlstate

raise type('MyError', (plpy.SPIError,), {'sqlstate': 'D000M'})(...)

将传播ERRCODE D000M并为我工作。

一个很好的方法是定义一个自定义HINT,但看起来更棘手,因为它带有spidata

答案 1 :(得分: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

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