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配置变量控制。详见
第 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(
。它们等效于第 9.4 节中描述的内建引用函数。在构建临时查询时它们能派上用场。例 42.1中动态
SQL 的 PL/Python 等效体是:string
)
plpy.execute("UPDATE tbl SET %s = %s WHERE key = %s" % (
plpy.quote_ident(colname),
plpy.quote_nullable(newvalue),
plpy.quote_literal(keyvalue)))
Image align 属性 Image 对象定义和用法align 属性可设置或者返回图像的 align 属性值。align 属性指定了与内联内容的对齐方式。...
Style orphans 属性 Style 对象定义和用法orphans 属性设置或返回一个元素必须在页面底部的可见行的最小数量(用于打印或打印预...
Style pageBreakInside 属性 Style 对象定义和用法pageBreakInside 属性设置或返回元素内的分页行为(用于打印或打印预览)。注...
Style minWidth 属性 Style 对象定义和用法minWidth 属性设置或返回元素的最小宽度。minWidth 属性只在块级元素或绝对/固定位置...
Table rules 属性 Table 对象定义和用法rules 属性可设置或返回表格的内部边线。语法设置 rules 属性:tableObject.rules="none|...
Style width 属性 Style 对象定义和用法width 属性设置或返回元素的宽度。width 属性只在块级元素或绝对/固定位置的元素发挥作用...
HTML DOM Title 对象Title 对象 Title 对象代表了一个HTML title 元素。访问 Title 对象你可以使用getElementsByTagName()来访问...
FIRST_VALUE是一个分析函数。它返回有序值中的第一个值。如果集合中的第一个值为NULL,则函数返回NULL,除非您指定IGNORE NULLS...