E.101. 版本 8.2
发布日期: 2006-12-05
E.101.1. 概述
这个版本添加了许多用户要求的功能和性能改善,包括:
查询语言增强包括
INSERT/UPDATE/DELETE RETURNING
, 多行VALUES
列表和UPDATE
/DELETE
中可选的目标表别名。不带有并发锁的索引创建
INSERT
/UPDATE
/DELETE
操作许多查询最优化改善,包括对重新排序外连接的支持
提高降低内存使用的排序性能
带有更好的并发性的更多有效的锁定
更有效的清理
简化热备服务器的管理
为表和索引新增
FILLFACTOR
支持监视、记录和性能调优的添加
对创建和删除对象的更多控制
表继承管理可以为已经存在的表定义或从已经存在的表中删除
COPY TO
可以拷贝任意SELECT
语句的输出数组的改进,包括空数组
聚集函数的改进,包括多重输入聚集和SQL:2003统计函数
许多
contrib/
的改进
E.101.2. 迁移到版本 8.2
想要从任何以前的版本中迁移数据的用户需要使用pg_dump转储/恢复。
观察下列的不兼容性:
缺省设置
escape_string_warning
为on
(Bruce)如果反斜杠逃逸在非逃逸(非
E''
)字符串 中使用,这会发出一个警告。修改行构造函数语法 (
ROW(...)
), 这样列表元素foo.*
将被扩展到一个他们的成员字段的列表, 而不是和以前一样创建一个嵌套的行类型字段 (Tom)新的行为实际上更有用,因为它允许,例如,触发器用
IF row(new.*) IS DISTINCT FROM row(old.*)
检查数据的改变。 通过省略.*
,仍然可以使用老的行为。让行比较遵循SQL 标准语义,并允许它们在索引扫描中使用 (Tom)
以前,row = 和 <>比较遵循标准,但是< <= > >=不遵循标准。 行比较现在可以用作多字段索引的索引约束匹配行值。
让row
IS [NOT] NULL
测试遵循SQL标准语义 (Tom)前者的行为在
IS NULL
的简单情况下符合标准,但是如果任意行字段是非空的,IS NOT NULL
将返回真,而标准认为只有所有字段都是非空的时才应该返回真。让
SET CONSTRAINT
只影响一个约束 (Kris Jurka)在以前的版本中,
SET CONSTRAINT
用一个匹配的名字修改所有的约束。 在这个版本中,模式搜索路径只用于修改第一个匹配的约束。 也支持模式声明。这更加符合SQL标准。因为安全原因,为表删除
RULE
权限 (Tom)这个版本,只有表的所有者可以为该表创建或修改规则。为了向后兼容, 仍然接受
GRANT
/REVOKE RULE
,但是它什么也不做。数组比较的改进 (Tom)
现在也比较数组的维度。
修改数组连接,以匹配记录的行为 (Tom)
这改变了串联会修改数组下界的以前的行为。
让postmaster和postgres 的命令行选项相同 (Peter)
这允许主进程不使用
-o
就能传递参数到每个后端。请注意, 某些选项现在只能用作长格式的选项,因为与单字母的选项有冲突。反对使用postmaster符号连接 (Peter)
postmaster和postgres命令现在动作相同, 行为由命令行选项决定。为了兼容性,保留了postmaster符号连接, 但是实际上不需要了。
修改
log_duration
, 使其在查询没有输出的情况下也输出 (Tom)在以前的版本中,
log_duration
只在查询出现在日志的前面时才输出。让
to_char(time)
和to_char(interval)
对待HH
和HH12
为12小时间隔大多数应用应该使用
HH24
,除非它们想要12小时显示。在从
INET
到CIDR
的转换中有零个未标记的位 (Tom)这确保了转换的值对于
CIDR
实际有效。删除
australian_timezones
配置变量 (Joachim Wieland)为了配置时区缩写,这个变量被一个更通用的设备取代。
为嵌套的循环索引扫描改善开销估计 (Tom)
这可以消除设置不切实际的小的
random_page_cost
值的需要。如果你已经使用了一个非常小的random_page_cost
,请重新检查你的测试用例。改变
pg_dump
-n
和-t
选项的行为。 (Greg Sabino Mullane)请查看
pg_dump
手册页获取细节。修改libpq
PQdsplen()
以返回一个有用的值 (Martijn van Oosterhout)声明libpq
PQgetssl()
返回void *
,而不是SSL *
(Martijn van Oosterhout)这允许应用不包括OpenSSL头使用函数。
为了版本兼容性检查,C语言可加载模块现在必须包括一个
PG_MODULE_MAGIC
宏调用 (Martijn van Oosterhout)为了安全起见,PL/PerlU函数使用的模块不再可用于PL/Perl函数 (Andrew)
> Note: 这也意味着数据在PL/Perl函数和PL/PerlU函数之间不再能够共享。 某些Perl安装没有用正确的允许多个解释器存在于一个进程中的标识编译。 在这种情况下,PL/Perl和PL/PerlU不能同时用于一个后端中。 解决办法是获得一个支持多个解释器的Perl安装。
在
contrib/xml2/
中,重命名xml_valid()
为xml_is_well_formed()
(Tom)为了向后兼容,将保留
xml_valid()
,但是它的行为将在未来的版本中改变为模式检查。删除
contrib/ora2pg/
,现在在http://www.samse.fr/GPL/ora2pg中删除已经迁移到PgFoundry的贡献模块:
adddepend
,dbase
,dbmirror
,fulltextindex
,mac
,userlock
删除废弃的贡献模块:
mSQL-interface
,tips
删除QNX和BEOS端口 (Bruce)
这些端口不再有活跃的维护者。
E.101.3. 修改列表
下面你将看到PostgreSQL 8.2和以前的主版本之间详细的变化。
E.101.3.1. 性能提升
允许规划器在某些情况下重新排序外连接 (Tom)
在以前的版本中,外连接总是以在查询中写入的顺序计算。这个修改允许查询优化器考虑重新排序外连接, 在它确定改变连接顺序而不改变查询的意思的情况下。这对于包含多个外连接或混合内部和外部连接的查询来说, 会产生一个可观的性能差异。
提高
IN
(表达式列表) 子句的效率 (Tom)提高排序速度和减少内存使用 (Simon, Tom)
提高子事务性能 (Alvaro, Itagaki Takahiro, Tom)
添加
FILLFACTOR
到表和 索引创建(ITAGAKI Takahiro)这在每个表或索引页中留有额外的自由空间,允许随着数据的增长提高性能。 这对于维护集群来说特别有价值。
为
shared_buffers
和max_fsm_pages
增加默认值 (Andrew)通过打断锁管理器表为部分,提高锁的性能 (Tom)
这允许锁定粒度更细,减少争用。
减少序列扫描的锁定需求 (Qingqing Zhou)
减少数据库创建和销毁的锁定需求 (Tom)
允许约束排除应用于 继承的
UPDATE
和DELETE
查询 (Tom)SELECT
早已遵循约束排除。改善常量
WHERE
子句的规划,比如一个只依赖于从一个外部查询级别继承的变量的条件 (Tom)协议级别未命名的预备语句是为每个
BIND
值组重新规划的 (Tom)因为准确的参数值可以在计划中使用,所以提高了性能。
加速清理B-Tree索引 (Heikki Linnakangas, Tom)
避免在
VACUUM
期间额外的扫描没有索引的表 (Greg Stark)提高多字段GiST索引 (Oleg, Teodor)
在B-Tree页分裂之前删除死的索引条目 (Junji Teramoto)
E.101.3.2. 服务器的变化
允许强制切换到一个新的事务日志文件 (Simon, Tom)
这对于保持热备份从服务器与主服务器同步是有价值的。事务日志文件切换现在在
pg_stop_backup()
期间也自动发生。这确保了恢复所需要的所有事务日志文件可以立即归档。添加WAL信息函数 (Simon)
为从
pg_stop_backup()
和相关函数显示的十六进制WAL位置中询问当前事务日志插入点和决定 WAL文件名添加函数。改善WAL重放期间从一个崩溃中恢复 (Simon)
服务器现在在WAL恢复期间定期的检查点,所以如果有一个崩溃, 未来的WAL恢复被缩短。这样如果崩溃了, 就消除了对热备份服务器重放自基础备份以来的整个日志的需要。
改善长期的WAL重放的可靠性 (Heikki, Simon, Tom)
以前,由于XID包围,向前推进超过20亿事务的尝试将不会工作。 这意味着热备服务器必须定期从干净的基础备份中重载。
添加
archive_timeout
, 强制事务日志文件在给定的时间间隔切换 (Simon)这为热备份服务器执行最大的复制延迟。
添加本地LDAP认证 (Magnus Hagander)
这对于不支持PAM的平台,比如Windows,尤其有用。
添加
GRANT CONNECT ON DATABASE
(Gevik Babakhani)这给出了数据库访问的SQL级别控制。它作为一个额外的过滤器工作,紧接着现有的
pg_hba.conf
控制。添加对SSL证书撤销列表 (CRL) 文件的支持 (Libor Hohoš)
服务器和libpq现在都能识别CRL文件。
GiST索引现在是可集群的 (Teodor)
删除例程自动清理服务器日志条目 (Bruce)
pg_stat_activity
现在显示自动清理活动。在单独的表而不是整个数据库中跟踪最大的XID寿命 (Alvaro)
这通过避免不必要的VACUUM,减少了阻止事务ID环绕中包括的开销。
添加最后的清理和分析时间戳字段到状态收集器 (Larry Rosenman)
这些值现在出现在
pg_stat_*_tables
系统视图中。提高统计监测的性能,尤其是
stats_command_string
(Tom, Bruce)这个版本缺省启用
stats_command_string
,现在它的开销是最小的。 这意味着pg_stat_activity
现在缺省将显示所有活动的查询。添加一个
waiting
字段到pg_stat_activity
(Tom)这允许
pg_stat_activity
显示所有包括在ps显示中的信息。添加配置参数
update_process_title
, 控制ps的显示是否为每个命令都更新了 (Bruce)在更新ps显示昂贵的平台上,有必要把这个关掉,完全依赖于
pg_stat_activity
显示状态信息。允许在配置设置中指定单位 (Peter)
例如,你现在可以设置
shared_buffers
为32MB
,而不是在心里转换大小。在
postgresql.conf
中添加对包含指令 的支持 (Joachim Wieland)改善协议级别预备/绑定/执行消息的记录 (Bruce, Tom)
这样的日志现在显示语句名字、绑定参数值和被执行查询的文本。另外, 当通过
log_min_error_statement
启用时,查询文本正确的包含在记录的错误消息中。阻止
max_stack_depth
被设置为不安全的值在我们可以决定实际内核堆栈深度限制的平台上(大多数是),确保
max_stack_depth
的初始缺省值是安全的,并拒绝尝试设置它为不安全的大值。在更多情况下的查询中启用突出显示错误位置 (Tom)
服务器现在能够为一些语义错误报告一个具体的错误位置(比如未识别的字段名), 而不是和以前一样只报告基本的语法错误。
修复
VACUUM
中"未能重新找到父键"错误 (Tom)在服务器重新启动期间清理
pg_internal.init
缓存文件 (Simon)这避免了PITR恢复之后缓存文件可能包含陈旧数据的风险。
修复通过
VACUUM
截断十亿字节范围的大关系时的竞态条件 (Tom)修复行级别锁上导致不需要的死锁错误的bug (Tom)
修复影响几十亿字节哈希索引的错误 (Tom)
每个后端进程现在是它自己的进程组领导 (Tom)
这允许查询取消退出从一个后端或归档/恢复进程中调用的子进程。
E.101.3.3. 查询的变化
添加
INSERT
/UPDATE
/DELETE
RETURNING
(Jonah Harris, Tom)这允许这些命令返回值,比如为一个新行计算序列键。在
UPDATE
的情况下, 返回来自行的更新版本的值。添加对多行
VALUES
子句的支持, 按照SQL标准 (Joe, Tom)这允许
INSERT
插入多行常量,或查询使用常量生成结果集。例如,INSERT ... VALUES (...), (...), ....
, andSELECT * FROM (VALUES (...), (...), ....) AS alias(f1, ...)
。允许
UPDATE
和DELETE
为目标表使用一个别名 (Atsushi Ogawa)SQL标准不允许在它们的命令中使用别名,但是许多数据库系统为了标记方便,无论如何都允许一个。
允许
UPDATE
在一个值的列表中设置多个字段值 (Susanne Ebrecht)这基本上是一个按对分配字段和值的速记。语法是
UPDATE tab SET (``_column_
, ...) = (_val_
, ...)。使行比较按照标准工作 (Tom)
格式<, <=, >, >=现在按字母顺序比较行,也就是,比较第一个元素, 如果相等则比较第二个元素,以此类推。以前它们在所有的元素上扩展成一个AND条件, 这既不是标准也不是非常有用。
添加
CASCADE
选项到TRUNCATE
(Joachim Wieland)这导致
TRUNCATE
自动包括通过外键引用指定的表的所有表。 虽然方便,但是这是一个危险的工具—小心的使用它!在同一个
SELECT
命令中支持FOR UPDATE
和FOR SHARE
(Tom)添加
IS NOT DISTINCT FROM
(Pavel Stehule)这个操作符类似于等于(
=
),但是当左侧和右侧的操作数都是NULL
时, 评估为真,当只有一侧为NULL
时评估为假,而不是在这些情况下生成NULL
。改善
UNION
/INTERSECT
/EXCEPT
使用的长度输出 (Tom)当所有对应的字段有相同的定义长度时,该长度用于结果,而不是一个通用的长度。
允许
ILIKE
为多字节编码工作 (Tom)内部的,
ILIKE
现在调用lower()
然后使用LIKE
。 地区设定的正则表达式模式在这些编码中仍然不工作。使
standard_conforming_strings
能变成on
(Kevin Grittner)这允许禁用字符串中的反斜杠逃逸,让PostgreSQL更加标准兼容。 为了向后兼容,缺省是
off
,但是未来的版本将改成缺省为on
。不要在子查询目标列表中平面化包含
volatile
函数的子查询 (Jaime Casanova)这阻止了由于
volatile
函数(比如random()
或nextval()
) 的多次评估引起的意外行为。它可能导致在不需要标记为volatile
的函数面前性能退化。添加系统视图
pg_prepared_statements
和pg_cursors
, 显示预备语句和打开的游标 (Joachim Wieland, Neil)这在池连接设置中非常有用。
在
EXPLAIN
和EXECUTE
中支持入口参数 (Tom)这允许,例如,JDBC
?
参数在这些命令中工作。如果SQL级别的
PREPARE
参数没有指定,那么从查询的内容中推断它们的类型 (Neil)协议层
PREPARE
早已这样做了。允许
LIMIT
和OFFSET
超过二十亿 (Dhanaraj M)
E.101.3.4. 对象操作的变化
添加
TABLESPACE
子句到CREATE TABLE AS
(Neil)这允许为新表指定表空间。
添加
ON COMMIT
子句到CREATE TABLE AS
(Neil)这允许临时表在事务提交时被截断或删除。该表缺省的行为是保持到会话结束。
添加
INCLUDING CONSTRAINTS
到CREATE TABLE LIKE
(Greg Stark)这允许容易的拷贝
CHECK
约束到一个新表。允许创建占位符(壳)类型 (Martijn van Oosterhout)
一个壳类型声明创建一个类型名,没有声明该类型的任何细节。 这使得壳类型是有用的,因为它允许更干净的声明类型的输入/输出函数, 它们在该类型被定义为"真的"之前必须存在。语法是
CREATE TYPE
_typename_
。聚集函数 现在支持多个输入参数 (Sergey Koposov, Tom)
添加新的聚集创建语法 (Tom)
新的语法是
CREATE AGGREGATE
_aggname_
(_input_type_
) (_parameter_list_
)。 更自然的支持新的多参数聚集功能。仍然支持以前的语法。添加
ALTER ROLE PASSWORD NULL
, 删除以前设置的角色密码 (Peter)为许多对象类型添加
DROP
对象IF EXISTS
(Andrew)这允许
DROP
操作一个不存在的对象时不会生成错误。添加
DROP OWNED
, 删除一个角色拥有的所有对象 (Alvaro)添加
REASSIGN OWNED
, 重新分配一个角色拥有的所有对象 (Alvaro)这个和上面的
DROP OWNED
,帮助删除角色。添加
GRANT ON SEQUENCE
语法 (Bruce)这是为了设置特定于序列的权限添加的。为了后向兼容, 仍然支持序列的
GRANT ON TABLE
。为序列添加
USAGE
权限, 只允许currval()
和nextval()
,不允许setval()
(Bruce)USAGE
权限允许更精细的控制序列访问。USAGE
允许用户增加一个序列,但是阻止他们使用setval()
设置该序列为任意值。添加
ALTER TABLE [ NO ] INHERIT
(Greg Stark)这允许继承动态调整,而不是只在表创建和销毁时。 这在使用继承实现表分区时是非常有价值的。
允许在全局对象上的注释全局存储 (Kris Jurka)
以前,附加到数据库的注释存储在单独的数据库中,使得它们无效, 并且没有规定注释规则或表空间。这个修改添加了一个新的共享目录
pg_shdescription
并在数据库、角色和表空间上存储注释。
E.101.3.5. 工具命令的变化
添加选项以允许索引创建时不阻塞并发的写入到表 (Greg Stark, Tom)
新的语法是
CREATE INDEX CONCURRENTLY
。 缺省的行为在索引被创建时仍然阻塞表的修改。提供咨询锁功能 (Abhijit Menon-Sen, Tom)
这是一个新的锁API,设计来替换曾经在/contrib/userlock中的那个。 userlock代码现在在pgfoundry上。
允许
COPY
转储SELECT
查询 (Zoltan Boszormenyi, Karel Zak)这允许
COPY
转储任意的SQL查询。 语法是COPY (SELECT ...) TO
。让
COPY
命令返回一个命令标签, 该标签包括拷贝的行数 (Volkan YAZICI)允许
VACUUM
终止行, 而不受其他并发VACUUM
操作的影响 (Hannu Krossing, Alvaro, Tom)让initdb 检测操作系统环境并相应的设置缺省
DateStyle
(Peter)这使得安装的
postgresql.conf
DateStyle
值更有可能正是所需要的。减少initdb显示的进展消息的数量 (Tom)
E.101.3.6. 日期/时间的变化
在
timestamp
的输入值中允许完整的时区名 (Joachim Wieland)例如,
'2006-05-24 21:11 America/New_York'::timestamptz
。支持可配置的时区缩写 (Joachim Wieland)
所需的一组时区缩写可以通过配置参数
timezone_abbreviations
选择。添加
pg_timezone_abbrevs
和pg_timezone_names
视图,显示支持的时区 (Magnus Hagander)添加
clock_timestamp()
、statement_timestamp()
和transaction_timestamp()
(Bruce)clock_timestamp()
是当前挂钟的时间,statement_timestamp()
是当前语句到达服务器的时间,transaction_timestamp()
是now()
的一个别名。允许
to_char()
打印本地化的月和日的名字 (Euler Taveira de Oliveira)允许
to_char(time)
和to_char(interval)
输出AM/PM规格 (Bruce)间隔和时间是看做24小时周期的,例如
25 hours
被认为是AM。添加新的函数
justify_interval()
, 调整间隔单位 (Mark Dilger)允许时区偏移距离GMT达到14:59
Kiribati使用GMT+14,所以我们最好接受它。
间隔计算的改进 (Michael Glaesemann, Bruce)
E.101.3.7. 其他数据类型和函数的变化
允许数组包含
NULL
元素 (Tom)允许分配数组元素与现有的项不连续 (Tom)
介于中间的数组位置将用null填充。这是符合SQL标准的。
为数组子集比较新增内建的操作符 (
@>
、<@
、&&
) (Teodor, Tom)这些操作符可以被使用GiST或GIN 索引的许多数据类型索引。
在
INET
/CIDR
值上添加方便的算术 操作 (Stephen R. van den Berg)新增的操作符是
&
(and)、|
(or)、~
(not)、inet
+
int8
、inet
-
int8
和inet
-
inet
。从SQL:2003添加新的聚集函数 (Neil)
新增的函数是
var_pop()
、var_samp()
、stddev_pop()
和stddev_samp()
。var_samp()
和stddev_samp()
只是重命名现有的聚集variance()
和stddev()
。后者的名字为了后向兼容仍然可用。添加SQL:2003统计聚集 (Sergey Koposov)
新增函数:
regr_intercept()
、regr_slope()
、regr_r2()
、corr()
、covar_samp()
、covar_pop()
、regr_avgx()
、regr_avgy()
、regr_sxy()
、regr_sxx()
、regr_syy()
、regr_count()
。允许domains基于其他的域 (Tom)
适当的加强域的
CHECK
约束 (Neil, Tom)例如,声明返回域类型的用户定义函数的结果现在检查该域的约束。 这关闭了域实现中的一个重大漏洞。
修复转储重命名的
SERIAL
字段的问题 (Tom)该修复是通过明确的指定序列的
DEFAULT
和序列元素转储一个SERIAL
,并且在重新加载时使用一个新的ALTER SEQUENCE OWNED BY
命令重新构造该SERIAL
的字段。这也允许删除一个SERIAL
字段声明。添加一个服务器端休眠函数
pg_sleep()
(Joachim Wieland)为
tid
(tuple id) 数据类型添加所有比较操作符 (Mark Kirkwood, Greg Stark, Tom)
E.101.3.8. PL/pgSQL服务器端语言的变化
添加
TG_table_name
和TG_table_schema
到触发器参数 (Andrew)TG_relname
现在已经废弃了。也为其他PL在触发器参数中做了类型的变化。允许
FOR
语句返回标量值、记录和行类型 (Pavel Stehule)添加一个
BY
子句到FOR
循环,控制迭代增量 (Jaime Casanova)添加
STRICT
到SELECT INTO
(Matt Miller)为了Oracle PL/SQL兼容性,如果多于或少于一行被
SELECT
返回, 则STRICT
模式抛出一个异常。
E.101.3.9. PL/Perl服务器端语言的变化
添加
table_name
和table_schema
到触发器参数 (Adam Sjøgren)添加预备查询 (Dmitry Karasik)
让
$_TD
触发一个全局变量的数据 (Andrew)在以前,这是一个词汇,引起意外的分享违规行为。
为了安全起见,在单独的解释器中运行PL/Perl和PL/PerlU (Andrew)
在序列中,它们再也不能分享数据和加载模块。另外, 如果Perl没有用必要的标识编译以允许多个解释器,那么在任何给出的后端进程中, 只可以使用这些语言中的一种。
E.101.3.10. PL/Python服务器端语言的变化
命名的参数是作为普通变量传送的,和在
args[]
数组中一样 (Sven Suursoho)添加
table_name
和table_schema
到触发器参数 (Andrew)允许返回复合类型和结果集 (Sven Suursoho)
作为
list
、iterator
或generator
返回结果集 (Sven Suursoho)允许函数返回
void
(Neil)现在支持Python 2.5了 (Tom)
E.101.3.11. psql 的变化
添加新的命令
\password
,用客户端侧的口令加密修改角色口令 (Peter)允许
\c
连接到一个新的主机和端口号 (David, Volkan YAZICI)添加表空间显示到
\l+
(Philip Yarra)改善
\df
斜线命令,包含函数的参数名和模式 (OUT
或INOUT
) (David Fetter)支持二进制
COPY
(Andreas Pflug)添加选项在一个事务中运行整个会话 (Simon)
使用选项
-1
或--single-transaction
。支持使用一个游标按批次的自动检索
SELECT
结果 (Chris Mair)这是使用
\set FETCH_COUNT
_n_
启用的。 这个特性允许在psql中检索大的结果集, 而不用尝试在内存中缓存整个结果集。让多行值对齐在适当的字段内 (Martijn van Oosterhout)
包含换行符的字段值现在以更可读的方式显示。
多行语句保存为一个条目,而不是一次一行 (Sergey E. Koposov)
这使得向上箭头调回查询更加简单。(在Windows上是不可用的, 因为该平台使用操作系统中的本地命令行编辑。)
让行计数器是64位的,这样它可以处理行数超过二十亿的文件 (David Fetter)
为
INSERT
/UPDATE
/DELETE RETURNING
报告返回的数据库和命令状态标签 (Tom)
E.101.3.12. pg_dump 的变化
允许对象的综合选择被pg_dump包括或排除 (Greg Sabino Mullane)
pg_dump现在支持多个
-n
(模式)和-t
(表)选项,并且添加了-N
和-T
选项排除对象。 另外,这些开关的参数现在可以是通配符表达式,而不是单个对象名, 例如-t 'foo*'
,并且一个模式可以是-t
或-T
开关的一部分,比如-t schema1.table1
。添加pg_restore
--no-data-for-failed-tables
选项,如果表创建失败则阻止加载数据 (也就是,该表早已存在) (Martin Pitt)添加pg_restore选项, 在单个事务中运行整个会话 (Simon)
使用选项
-1
或--single-transaction
。
E.101.3.13. libpq 的变化
添加
PQencryptPassword()
, 用来加密口令 (Tom)这允许口令对于像
ALTER ROLE ... PASSWORD
这样的命令是预先加密发送的。添加函数
PQisthreadsafe()
(Bruce)这允许应用查询该库的线程安装状态。
添加
PQdescribePrepared()
、PQdescribePortal()
和相关的函数返回关于以前预备好的语句和打开的游标的信息 (Volkan YAZICI)允许LDAP从
pg_service.conf
中查找 (Laurenz Albe)允许
~/.pgpass
中的主机名匹配缺省的套接字目录 (Bruce)一个空的主机名继续匹配任何Unix套接字连接, 但是这个添加允许记录特定于机器上的几个主进程之一。
E.101.3.14. ecpg 的变化
允许
SHOW
将它的结果放入一个变量中 (Joachim Wieland)添加
COPY TO STDOUT
(Joachim Wieland)添加回归测试 (Joachim Wieland, Michael)
主要源代码清理 (Joachim Wieland, Michael)
E.101.3.15. Windows 端口
允许MSVC编译PostgreSQL服务器 (Magnus, Hiroshi Saito)
为实用命令和pg_dump 添加MSVC支持 (Hiroshi Saito)
为Windows代码页
1253
、1254
、1255
和1257
添加支持 (Kris Jurka)在启动时删除权限,这样服务器可以从一个管理员账号启动 (Magnus)
稳定性修复 (Qingqing Zhou, Magnus)
添加本地信号灯实现 (Qingqing Zhou)
以前的代码模仿SysV信号灯。
E.101.3.16. 源代码的变化
添加GIN (Generalized Inverted iNdex) 索引访问方法 (Teodor, Oleg)
删除R-tree索引 (Tom)
Rtree已经使用GiST重新实现了。 在其他差异中,这意味着rtree索引现在支持通过预写式日志(WAL)崩溃恢复。
减少库不必要的连接到后端 (Martijn van Oosterhout, Tom)
添加一个配置标志,允许libedit优先于GNU readline (Bruce)
允许安装到包含空格的目录 (Peter)
提高重新定位安装目录的能力 (Tom)
为使用Solaris编译器的Solaris x86_64 添加支持 (Pierre Girard, Theo Schlossnagle, Bruce)
添加DTrace支持 (Robert Lor)
添加
PG_VERSION_NUM
,供想要使用>和< 比较测试后端C语言版本第三方应用程序使用 (Bruce)添加
XLOG_BLCKSZ
,独立于BLCKSZ
(Mark Wong)添加
LWLOCK_STATS
定义,报告锁定活动 (Tom)为未知的configure选项发出警告 (Martijn van Oosterhout)
为"plugin"库添加服务器支持,可以用于附加任务,比如调试和性能测量 (Korry Douglas)
这由两个功能组成:一个允许单独加载的共享库沟通的"会合变量"的表, 和一个允许库被加载到特定会话而不明确与客户端应用合作的新的配置参数
local_preload_libraries
。 这允许外部插件实现像PL/pgSQL调试器这样的特性。重命名现有的配置参数
preload_libraries
为shared_preload_libraries
(Tom)这样做是为了清楚的和
local_preload_libraries
比较。添加新的配置参数
server_version_num
(Greg Sabino Mullane)这类似于
server_version
,但是这是一个整数,例如80200
。 这允许应用更容易的做版本检查。添加配置参数
seq_page_cost
(Tom)重新实现回归测试脚本为C程序 (Magnus, Tom)
允许可加载的模块分配共享内存和轻量级锁 (Marc Munro)
添加动态加载库的自动初始化和终结 (Ralf Engelschall, Tom)
如果库定义了这样的符号,则新增的函数
_PG_init()
和_PG_fini()
被调用。 因此我们不再需要在shared_preload_libraries
中指定一个初始化函数;我们可以假设库使用了_PG_init()
约定。添加
PG_MODULE_MAGIC
标题块到所有共享的对象文件 (Martijn van Oosterhout)该魔法模块阻止可加载对象文件和服务器间的版本错误匹配。
为AIX添加共享的库支持 (Laurenz Albe)
新增XML文档章节 (Bruce)
E.101.3.17. 贡献包的变化
主要tsearch2的改进 (Oleg, Teodor)
多字节编码支持,包括UTF8
查询重写的支持
改进排序功能
同义词字典支持
Ispell字典现在识别MySpell格式,OpenOffice使用它。
GIN支持
添加包含Pgadmin管理功能的adminpack模块 (Dave)
这些函数提供了没有在缺省的PostgreSQL 服务器中出现的额外的文件系统访问例程。
添加sslinfo模块 (Victor Wagner)
报告当前连接的SSL证书的信息。
添加pgrowlocks模块 (Tatsuo)
这为特定的表显示了行锁信息。
添加hstore模块 (Oleg, Teodor)
添加isn模块,替换isbn_issn (Jeremy Kronuz)
这个新的实现支持EAN13、UPC、 ISBN (books)、ISMN (music)和ISSN (serials)。
添加索引信息函数到pgstattuple (ITAGAKI Takahiro, Satoshi Nagayasu)
添加pg_freespacemap模块,显示自由空间映射信息 (Mark Kirkwood)
pgcrypto现在拥有所有计划的功能 (Marko Kreen)
在pgcrypto中包含iMath库,让公共秘钥加密函数总是可用。
添加在OpenBSD代码中丢失的SHA224算法。
在老的OpenSSL上为SHA224/256/384/512哈希激活内建代码,让这些算法总是可用。
新增函数gen_random_bytes(),返回密码强壮的随机性。对于生成加密秘钥是有用的。
删除digest_exists()、hmac_exists()和cipher_exists()函数。
改进多维数据集模块 (Joshua Reich)
新增的函数是
cube(float[])
、cube(float[], float[])
和cube_subset(cube, int4[])
。添加异步查询能力到dblink (Kai Londenberg, Joe Conway)
为数组子集比较新增操作符(
@>
、<@
、&&
) (Tom)各种贡献包已经为它们的数据类型有了这些操作符,但是命名并不一致。 我们现在添加了一致命名的数组子集比较操作符到内核代码和所有拥有这样功能的贡献包。 (老的名字保留有效,但是已经废弃了。)
为所有拥有安装脚本的贡献包添加卸载脚本 (David, Josh Drake)