dm-redis-adapter

This is a DataMapper adapter for the Redis key-value database.

Redis is a very fast key-value store with some interesting data structures added. You can have a key that is a SET, LIST, or a STRING that is binary safe. Data structures like SET and LIST allow for even more interesting things. Redis is a fabulous and fast engine for data structures, and you can read more about it here: redis. Redis is also a persistent data store, and can be used in large-scale environments with master-slave replication and consistent hashing on the client side.

DataMapper is a brilliant ORM that is based on the IdentityMap pattern. Usage of DataMapper resembles that of ActiveRecord, the popular ORM bundled with Ruby on Rails, but with some very important differences. A quote from the DM wiki: “One row in the database should equal one object reference. Pretty simple idea. Pretty profound impact.” Having an identity map allows for very efficient queries to the database, as well as interesting forms of lazy loading of attributes or associations.

Marrying DataMapper to Redis allows for schema-less models, you can add fields at any time without having to create a migration. DataMapper also allows us to store non-native Redis types in the db, like Date fields.

Install

Prerequisites:

Install the dm-redis adapter:


    > gem sources -a http://gems.github.com
    > sudo gem install whoahbot-dm-redis-adapter
  

Usage

Setup your adapter, define your models and properties:


    require 'rubygems'
    require 'dm-core'
    require 'dm_redis'
    
    DataMapper.setup(:default, {:adapter  => "redis"})
    
    class Cafe
      include DataMapper::Resource
      
      property :id,     Serial
      property :name,   Text
    end
    
    Cafe.create(:name => "Whoahbot's Caffienitorium")

Now you can use redis in a ORM style, and take advantage of all of the amazing things that DataMapper offers.

Badass contributors