44.10. Вспомогательные функции
Модуль plpy также предоставляет функции 
| plpy.debug( | 
| plpy.log( | 
| plpy.info( | 
| plpy.notice( | 
| plpy.warning( | 
| plpy.error( | 
| plpy.fatal( | 
 Функции plpy.error и plpy.fatal на самом деле выдают исключение Python, которое, если его не перехватить, распространяется в вызывающий запрос, что приводит к прерыванию текущей транзакции или подтранзакции. Команды raise plpy.Error( и msg)raise plpy.Fatal( равнозначны вызовам msg)plpy.error( и msg)plpy.fatal(, соответственно, но форма msg)raise не позволяет передавать аргументы с ключами. Другие функции просто выдают сообщения разных уровней важности. Будут ли сообщения определённого уровня передаваться клиентам и/или записываться в журнал сервера, определяется конфигурационными переменными log_min_messages и client_min_messages. За дополнительными сведениями обратитесь к Главе 18.
Аргумент msg задаётся как позиционный. Для обратной совместимости может быть передано несколько позиционных аргументов. В этом случае сообщением для клиента становится строковое представление кортежа позиционных аргументов.
Дополнительно только по ключам принимаются следующие аргументы:
| detail | 
| hint | 
| sqlstate | 
| schema_name | 
| table_name | 
| column_name | 
| datatype_name | 
| constraint_name | 
Строковое представление объектов, передаваемых в аргументах по ключам, позволяет выдать клиенту более богатую информацию. Например:
CREATE FUNCTION raise_custom_exception() RETURNS void AS $$
plpy.error("custom exception message",
           detail="some info about exception",
           hint="hint for users")
$$ LANGUAGE plpythonu;
=# SELECT raise_custom_exception();
ERROR:  plpy.Error: custom exception message
DETAIL:  some info about exception
HINT:  hint for users
CONTEXT:  Traceback (most recent call last):
  PL/Python function "raise_custom_exception", line 4, in <module>
    hint="hint for users")
PL/Python function "raise_custom_exception"Ещё один набор вспомогательных функций образуют plpy.quote_literal(, строка)plpy.quote_nullable( и строка)plpy.quote_ident(. Они равнозначны встроенным функциям заключения в кавычки, описанным в Разделе 9.4. Они полезны при конструировании свободно составляемых запросов. На PL/Python динамический SQL, показанный в Примере 41.1, формируется так: строка)
plpy.execute("UPDATE tbl SET %s = %s WHERE key = %s" % (
    plpy.quote_ident(colname),
    plpy.quote_nullable(newvalue),
    plpy.quote_literal(keyvalue)))