E.181. 版本 8.1.12
发布日期: 从未发布
这个版本包含各种自8.1.11以来的修复。关于8.1主版本的新特性信息, 请查看第 E.193 节。
E.181.1. 迁移到版本 8.1.12
运行8.1.X的用户不需要转储/恢复。不过,如果你是从一个早于8.1.2的版本升级而来, 那么请查看第 E.191 节。
E.181.2. 修改列表
-
修复ALTER TABLE ADD COLUMN ... PRIMARY KEY, 这样新的字段正确的检查是否它被初始化为所有都是非空 (Brendan Jurd)
以前的版本完全忽略了检查这个要求。
修复从多个继承自同一个祖先的约束的父关系中继承"相同的"约束时, 可能的CREATE TABLE失败 (Tom)
修复ISO-8859-5和其他编码之间的转换,以处理Cyrillic "Yo"字符 (e和E带有两个句点) (Sergey Burladyan)
-
修复一个新的日期类型输入函数, 允许未使用的字节在它们的结果中包含未初始化的、不可预测的值 (Tom)
这会导致两个表面上相同的文字值不被看做相等的失败, 导致解析器抱怨不匹配的ORDER BY和DISTINCT表达式。
-
修复正则表达式子串匹配中的一个极端情况(substring(string from pattern)) (Tom)
当有一个到模式的完全匹配,但是用户已经指定了一个加上括号的子表达式, 并且该子表达式没有获得一个匹配时会发生这个问题。一个例子是 substring('foo' from 'foo(bar)?')。这个应该返回NULL, 因为(bar)没有匹配,但是它错误的返回了整个模式匹配 (也就是foo)。
更新时区数据文件到tzdata版本2008c (因为DST规律在Morocco、Iraq、Choibalsan、Pakistan、Syria、Cuba、 Argentina/San_Luis和Chile发生了改变)
修复ecpg的
PGTYPEStimestamp_sub()
函数中的不正确的结果 (Michael)当输入查询返回一个NULL值时,修复contrib/xml2的
xpath_table()
函数中的内核转储 (Tom)修复contrib/xml2的makefile,不要覆盖CFLAGS (Tom)
-
修复DatumGetBool宏,不要在使用gcc 4.3时失败 (Tom)
这个问题影响返回布尔的"老式的" (V0) C函数。 这个修复在8.3中已经有了,但是后向修复它的需要在当时没有意识到。
-
修复长期存在的LISTEN/NOTIFY竞态条件 (Tom)
在罕见的情况下,刚刚执行了LISTEN的会话可能不会获得一个通知, 即使预期应该有一个通知,因为并发事务执行NOTIFY是在提交之后能观察到。
该修复的一个副作用是一个刚刚执行了暂未提交的LISTEN命令的事务将不会看到 该LISTEN的pg_listener中的任何行,而它应该能看到的; 以前它是能够看到的。这个行为不管怎样都没有记录过,但是有可能一些应用依赖于老的行为。
-
不允许LISTEN和UNLISTEN在一个准备事务中 (Tom)
这在以前是允许的,但是尝试这样做会有各种不愉快的后果, 尤其是只要UNLISTEN保持未提交,原始的后端就不能退出。
修复在查询使用哈希索引期间发生错误时的罕见的崩溃 (Heikki)
-
修复公元前的年中二月29的日期时间值的输入 (Tom)
以前的代码弄错了哪一年是闰年。
修复在某些ALTER OWNER的变体中的"未识别的节点类型"错误 (Tom)
-
修复pg_ctl,正确的从命令行选项中提取主进程的端口号 (Itagaki Takahiro, Tom)
以前,pg_ctl start -w尝试在错误的端口连接主进程, 导致启动失败的虚假的报告。
-
使用-fwrapv防卫在最近的gcc版本中可能的错误最优化 (Tom)
这在用gcc 4.3或更新的版本建立PostgreSQL时是必需的。
-
修复ORDER BY和GROUP BY中常量表达式的显示 (Tom)
一个显示转换的常量将会不正确的显示。这会导致例如转储和重载期间视图定义的损坏。
-
修复libpq,以在COPY OUT期间正确的处理NOTICE消息 (Tom)
只有当用户定义的数据类型的输出例程发出一个NOTICE时,这个失败才能观察到, 但是不保证它不会因为其他原因发生。