codecamp

PostgreSQL 实用函数

plpy模块也提供了函数

plpy.debug(msg, **kwargs )
plpy.log(msg, **kwargs )
plpy.info(msg, **kwargs )
plpy.notice(msg, **kwargs )
plpy.warning(msg, **kwargs )
plpy.error(msg, **kwargs )
plpy.fatal(msg, **kwargs )

plpy.errorplpy.fatal实际上会产生一个 Python 异常(如果没被捕捉),它会被传播到调用查询中导致当前事务或者子事务被中止。raise plpy.Error(msg )raise plpy.Fatal(msg )分别等效于调用plpy.error(msg )plpy.fatal(msg ),不过raise形式不允许传递关键词参数。其他函数只生成不同优先级的消息。一个特定优先级的消息是被报告给客户端、写入服务器日志还是两者都做,由log_min_messagesclient_min_messages配置变量控制。详见 第 19 章

msg参数被给定位一个位置参数。为了向后兼容,可以给出多于一个位置参数。在那种情况下, 位置参数形成的元组的字符串表达将会变成报告给客户端的消息。

下列 keyword-only 参数会被接受:

detail
hint
sqlstate
schema_name
table_name
column_name
datatype_name
constraint_name

作为 keyword-only 参数传递的对象的字符串表达可以用来丰富报告给客户端的消息。例如:

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(string )plpy.quote_nullable(string )以及plpy.quote_ident(string )。它们等效于第 9.4 节中描述的内建引用函数。在构建临时查询时它们能派上用场。例 42.1中动态 SQL 的 PL/Python 等效体是:

plpy.execute("UPDATE tbl SET %s = %s WHERE key = %s" % (
    plpy.quote_ident(colname),
    plpy.quote_nullable(newvalue),
    plpy.quote_literal(keyvalue)))


PostgreSQL 事务管理
PostgreSQL 环境变量
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

PostgreSQL SQL语言

PostgreSQL 服务器管理

PostgreSQL 客户端接口

PostgreSQL 服务器编程

PostgreSQL 参考

PostgreSQL 内部

PostgreSQL 附录

PostgreSQL 参考书目

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }