发布日期:. 2010-12-16
这个版本包含各种自8.2.18以来的修复。关于8.2主版本的新特性信息, 请查看第 E.202 节。
运行8.2.X的用户不需要转储/恢复。不过,如果你是从一个早于8.2.14的版本升级而来, 那么请查看第 E.188 节。
强制Linux上wal_sync_method
的缺省为fdatasync
(Tom Lane, Marti Raudsepp)
在Linux上的该缺省实际上是fdatasync
已经很多年了,
但是最近的内核更改导致PostgreSQL选择了open_datasync
。
这个选择没有导致任何性能改善,并且在某些文件系统上引起彻底的失败,
尤其是带有data=journal
挂载选项的ext4
。
为GIN索引修复WAL重放逻辑中的各种错误 (Tom Lane)
这可能在复制期间导致“bad buffer id: 0”失败或索引内容的损坏。
当开始检查点WAL记录和它的重做点不在相同的WAL段时,修复从基础备份的恢复 (Jeff Davis)
添加对检测IA64
上寄存器堆栈溢出的支持 (Tom Lane)
IA64
体系结构有两个硬件堆栈。堆栈溢出失败的全面预防需要两个堆栈都检查。
为copyObject()
中的堆栈溢出添加检查 (Tom Lane)
由于堆栈溢出给出一个足够复杂的查询,某些代码路径可能会崩溃。
修复临时GiST索引中页分裂的检测 (Heikki Linnakangas)
在一个临时索引中有“并发的”页分裂是可能的,比如说, 执行一个插入时有一个打开的游标扫描索引。GiST未能检测这个情况, 并且因此在该游标的执行继续时会交付错误的结果。
当ANALYZE
复杂索引表达式时,避免内存泄露 (Tom Lane)
确保使用整行变量的索引仍然依赖于它的表 (Tom Lane)
像create index i on t (foo(t.*))
这样声明的索引,
在它的表被删除时,将不会自动被删除。
不要用多个OUT
参数“inline”一个SQL函数 (Tom Lane)
这避免了由于丢失预期的结果行类型的信息而引起的可能的崩溃。
如果ORDER BY
、LIMIT
、FOR UPDATE
或
WITH
附属于INSERT ... VALUES
的VALUES
部分则正确的行为 (Tom Lane)
修复COALESCE()
表达式的常量折叠 (Tom Lane)
规划器有时会尝试计算实际永远不可能达到的子表达式,可能导致意外的错误。
为InhRelation
节点添加打印功能 (Tom Lane)
这避免了启用debug_print_parse
并且执行了某些类型的查询时的失败。
修复点到水平线段的距离的不正确的计算 (Tom Lane)
这个错误影响几个不同的几何距离测量操作。
修复PL/pgSQL对“简单”表达式的处理, 在递归或错误恢复的情况下不会失败 (Tom Lane)
修复PL/Python对设置返回函数的处理 (Jan Urbanski)
尝试在迭代器中调用SPI函数生成一组结果将会失败。
修复contrib/cube
的GiST picksplit算法中的错误 (Alexander Korotkov)
这会导致相当大的低效,尽管不是实际上不正确的答案,在一个cube
字段的GiST索引中。
如果你有这样的一个索引,考虑在安装这个更新之后REINDEX
它。
不要在contrib/dblink
中发出“标识符将被截断”的通知,
除非创建新的连接 (Itagaki Takahiro)
修复contrib/pgcrypto
中丢失的公共键上潜在的内核转储 (Marti Raudsepp)
修复contrib/xml2
的XPath查询函数中的内存泄露 (Tom Lane)
更新时区数据文件到tzdata版本2010o, 因为DST规律在Fiji和Samoa发生了改变;还为Hong kong做了历史纠正。