-
array_nulls
(
boolean
)
-
这个参数控制数组输入解析器是否把未用引号的
NULL
识别为一个空数组元素。默认为
on
,允许输入包含空值的数组值。但是
PostgreSQL
8.2 之前的版本不支持数组中的空值,并且因此将把
NULL
当作指定一个值为字符串
"NULL"
的正常数组元素。对于那些要求旧行为的应用的向后兼容性,这个变量可以被设置为
off
。
注意即使这个变量为
off
也能够创建包含空值的数组值。
-
backslash_quote
(
enum
)
-
这个参数控制字符串文本中的单引号是否能够用
\'
来表示。首选的 SQL 标准的方法是将其双写(
''
),但是
PostgreSQL
在历史上也接受
\'
。不过使用
\'
容易导致安全风险,因为在某些客户端字符集编码中,有多字节字符的最后一个字节在数值上等价于 ASCII 的
\'
。如果客户端代码没有做到正确转义,那么将会导致 SQL 注入攻击。如果服务器拒绝看起来带有被反斜线转义的单引号的查询,那么就可以避免这种风险。
backslash_quote
的可用值是
on
(总是允许
\'
)、
off
(总是拒绝)以及
safe_encoding
(只有客户端编码不允许在多字节字符中存在 ASCII
\
时允许)。
safe_encoding
是默认设置。
注意在符合标准的字符串文本中,
\
就表示
\
。这个参数只影响不符合标准的文本的处理,包括转义字符串语法(
E'...'
)。
-
default_with_oids
(
boolean
)
-
这个参数控制
CREATE TABLE
和
CREATE TABLE AS
在既没有指定
WITH OIDS
也没有指定
WITHOUT OIDS
的情况下,是否在新创建的表中包含 OID 列。它还决定被
SELECT INTO
创建的表里面是否包含 OID 。这个参数在默认情况下为
off
。在
PostgreSQL
8.0 及更早的版本中,它默认为
on
。
我们反对在用户表中使用 OID ,因此大多数安装应该禁用这个变量。需要为一个特殊表使用 OID 的应用应该在创建表的时候指定
WITH OIDS
。为了兼容不遵循这一行为的老旧应用,这个变量可以被启用。
-
escape_string_warning
(
boolean
)
-
打开时,如果在普通字符串文本中(
'...'
语法)出现了 一个反斜线(
\
)并且
standard_conforming_strings
为关闭,那么就会发出一个警告。默认值是
on
。
希望使用反斜线作为转义符的应用应该被修改来使用转义字符串语法(
E'...'
),因为在 SQL 标准中普通字符串的默认行为是将反斜线视作一个普通字符。这个变量可以被启用来帮助定位需要被更改的代码。
-
lo_compat_privileges
(
boolean
)
-
在9.0之前的版本中,大对象没有连接权限,并且对所有用户哦都市可读可写的。 将这个变量设置为on,从而禁用新的权限检查,以与以前的版本兼容。 默认是off。In
PostgreSQL
releases prior to 9.0, large objects
did not have access privileges and were, therefore, always readable
and writable by all users. Setting this variable to
on
disables the new privilege checks, for compatibility with prior
releases. The default is
off
.
只有超级用户可以更改这个设置。
设置这个参数不会禁用所有与大对象相关的安全检查 — 除了那些在
PostgreSQL
9.0中已经修改了的默认行为。例如,
lo_import()
和
lo_export()
需要超级用户权限而不管这个设置。
-
operator_precedence_warning
(
boolean
)
-
当开启时,解析器为了可能修改的任何结构发出警告,
意味着
PostgreSQL
9.4操作符优先级中作为修改结果。
对审计应用程序是非常有用的,
看看是否优先更改会打断任何东西;
但它并不意味着在生成过程中保持开启,
因为它会对一些完全有效的,符合标准的SQL代码发出警告。
缺省
off
。
参阅
第 4.1.6 节
获取更多信息。
-
quote_all_identifiers
(
boolean
)
-
当数据库产生 SQL 时,强制所有标识符被引号包围,即使它们(当前)不是关键字。这将影响
EXPLAIN
的输出以及
pg_get_viewdef
等函数的结果。另请参阅
pg_dump
和
pg_dumpall
的
--quote-all-identifiers
选项。
-
sql_inheritance
(
boolean
)
-
这个设置控制未修饰的表引用是否被视作要包括继承的子表。默认值是
on
,它表示包括子表(因此,默认假定一个
*
后缀)。如果被设置为
off
,不包括子表(因此,假设一个
ONLY
前缀)。SQL 标准要求子表被包括在内,因此
off
设置不是说明兼容的,但是被提供用来满足对
PostgreSQL
版本 7.1 之前的兼容性。详见
第 5.9 节
。
我们已经废弃了关闭
sql_inheritance
,因为那个行为已经被发现容易产生错误并且与 SQL 标准矛盾。本手册中其他地方讨论继承行为时通常假设它被设置为
on
。
-
standard_conforming_strings
(
boolean
)
-
控制普通字符串文本(
'...'
)是否按照 SQL 标准把反斜线当普通文本。从
PostgreSQL
9.1 开始,默认值为
on
(之前的发行中默认值为
off
)。应用可以检查这个参数来判断字符串文本如何被处理。这个参数的存在也可以被当做转义字符串语法(
E'...'
)被支持的标志。如果一个应用希望反斜线被当做转义字符,应该使用转义字符串语法(
第 4.1.2.2 节
)。
-
synchronize_seqscans
(
boolean
)
-
它允许对大型表的顺序扫描与其他扫描同步,因此并发扫描可以在几乎相同的时刻读取相同的块,这样可以分担 I/O 负载。当启用这个参数时,一个扫描可能会从表的中间开始并且之后
"绕回"
到开头以覆盖所有的行,这样可以与已在进行中的扫描活动同步。对于没有
ORDER BY
子句的查询来,这样的扫描会在返回行的顺序中造成不可预料的改变。将这个参数设置为
off
以保证 8.3 之前的行为(顺序扫描总是从表的起始处开始)。默认值是
on
。