Pg is the database driver for the PostgreSQL RDBMS.
The major feature of this release is a new typecasting system written by my co-maintainer Lars Kanis. It's mostly for people writing other libraries on top of database drivers such as Sequel, ActiveRecord, Datamapper, etc., but if you're curious there's a good overview of the system in the README (http://deveiate.org/code/pg/README_rdoc.html#label-Type+Casts).
Here are the details of what's in this release:
Bugfixes:
- Fix OID to Integer mapping (it is unsigned now). #187
- Fix possible segfault in conjunction with notice receiver. #185
Enhancements:
- Add an extensible type cast system.
- A lot of performance improvements.
- Return frozen String objects for result field names.
- Add PG::Result#stream_each and #stream_each_row as fast helpers for
the single row mode.
- Add Enumerator variant to PG::Result#each and #each_row.
- Add PG::Connection#conninfo and #hostaddr.
- Add PG.init_openssl and PG.init_ssl methods.
- Force zero termination for all text strings that are given to libpq.
It raises an ArgumentError if the string contains a null byte.
- Update Windows cross build to PostgreSQL 9.3.
Many thanks to the people like Mina Naguib, Jeremy Evans, Cody Cutrer, and Sam Saffron who helped us test the new system, and submitted great bug reports. A special thanks to Lars, who worked for half a year to come up with a system that is simple yet flexible enough to let people use whatever types they require while maintaining backward compatibility!
Please do let us know if you encounter any problems, preferably via the issue tracker (https://bitbucket.org/ged/ruby-pg/issues) or the Google Groups list (https://groups.google.com/forum/#!forum/ruby-pg).
Also, please note that this will be the last version that will support PostgreSQL 8.4, which reached its end-of-life last July (http://www.postgresql.org/support/versioning/).
···
--
Michael Granger <ged@FaerieMUD.org>
Rubymage, Architect, Believer
The FaerieMUD Consortium <http://faeriemud.org/>