ANN: Sequel 0.1.7 Released

Sequel version 0.1.7 has just been released. This is mainly a bug fix
release, but there is also some new functionality, mainly convenience
methods, and a new pagination feature. Following is a discussion of
the main changes:

Pagination

···

=========

If you're using Sequel in an MVC setting you might find this one
useful. A new Dataset#paginate method provides a very simple
pagination interface. Here's a contrived example:

  def search
    @recipes = Recipe.filter('body LIKE ?',
params[:search]).paginate(params[:page], params[:page_size])
  end

What you get back from #paginate is just a regular dataset, but with
the following methods:

  @recipes.page_count #=> the total number of pages available
  @recipes.current_page #=> the current page number
  @recipes.prev_page #=> the previous page number or nil if we're on
the first page
  @recipes.next_page #=> the next page number or nil if we're on the
last page

Dataset#[]= for updating records

New shorthand for conditional UPDATEs. Instead of:

  items.filter(:group_id => 29).update(:stamp => Time.now)

You can now write:

  items[:group_id => 29] = {:stamp => Time.now}

More concise first and last calls

Dataset#first and Dataset#last now accept hashes for specifying
filters, so now you can drop the filter call. Instead of:

  people.filter(:name => 'sharon').first

You can now write:

  items.first(:name => 'sharon')

More concise opening of databases

Sequel now defines a Sequel method call, so instead of:

  DB = Sequel.open 'sqlite:/'

You can now write:

  DB = Sequel('sqlite:/')

Bug fixes

* Implemented Model.join method to restrict returned columns to the
model table (thanks Pedro Gutierrez).

* Fixed after_destroy hook to actually work.

* Fixed Dataset#first to include a LIMIT clause for a single record.

* Small fix to Postgres driver to return a primary_key value for the
inserted record if it is specified in the insertion values (thanks
Florian Aßmann and Pedro Gutierrez).

* Fixed Symbol#DESC to support qualified notation (thanks Pedro
Gutierrez).

======================

Sequel documentation:
  <http://sequel.rubyforge.org>

Join the Sequel-talk group:
  <http://groups.google.com/group/sequel-talk>

Install the gem:
  sudo gem install sequel

Or check out the source and install manually:
  svn co http://ruby-sequel.googlecode.com/svn/trunk sequel
  cd sequel
  rake install