2010-02-23 20:43:05 +01:00
|
|
|
Dependencies
|
|
|
|
============
|
|
|
|
|
2011-08-25 11:15:32 +02:00
|
|
|
You need first the [Bdb](http://github.com/ruby-bdb/bdb) and of course [ruby](http://ruby-lang.org).
|
2010-02-23 20:43:05 +01:00
|
|
|
|
|
|
|
Download
|
|
|
|
========
|
|
|
|
|
|
|
|
via git:
|
|
|
|
|
2011-08-25 11:15:32 +02:00
|
|
|
git clone git://github.com/ruby-bdb/sbdb
|
2010-02-23 20:43:05 +01:00
|
|
|
|
|
|
|
Install
|
|
|
|
=======
|
|
|
|
|
|
|
|
gem build sbdb.gemspec
|
|
|
|
gem install sbdb-*.gem
|
|
|
|
|
|
|
|
Usage
|
|
|
|
=====
|
|
|
|
|
|
|
|
First, open environment and database
|
|
|
|
|
|
|
|
require 'sbdb'
|
|
|
|
Dir.mkdir 'newenv' rescue Errno::EEXIST
|
2011-08-25 13:48:26 +02:00
|
|
|
env = SBDB::Env.new 'newenv', SBDB::CREATE | SBDB::Env::INIT_TRANSACTION
|
|
|
|
db = env.btree 'newdb.db', :flags => SBDB::CREATE
|
2010-02-23 20:43:05 +01:00
|
|
|
|
|
|
|
It works nearly like a Ruby-Hash:
|
|
|
|
|
|
|
|
db['key'] = 'value'
|
2011-08-25 13:48:26 +02:00
|
|
|
db['key'] # => 'value'
|
|
|
|
db.to_hash # => {'key'=>'value'}
|
|
|
|
db.map {|k, v| "k => v" } # => ["key => value"]
|
|
|
|
db.count # => 1
|
|
|
|
db.each {|k,v| puts "#{k}: #{v}" }
|
2010-02-23 20:43:05 +01:00
|
|
|
|
2011-08-25 13:48:26 +02:00
|
|
|
`SBDB::DB#each` uses a `SBDB::Cursor`:
|
2010-02-23 20:43:05 +01:00
|
|
|
|
|
|
|
cursor = db.cursor
|
2011-08-25 13:48:26 +02:00
|
|
|
cursor.each {|k,v| puts "#{k}: #{v}" }
|
2010-02-23 20:43:05 +01:00
|
|
|
|
|
|
|
**Don't forget to close everything, you've opened!**
|
|
|
|
|
|
|
|
cursor.close
|
|
|
|
db.close
|
|
|
|
env.close
|
|
|
|
|
|
|
|
But you can use a *lambda* to ensure to close everything:
|
|
|
|
|
2011-08-25 13:48:26 +02:00
|
|
|
SBDB::Env.new( 'newenv', SBDB::CREATE | SBDB::Env::INIT_TRANSACTION) do |env|
|
2010-02-23 20:43:05 +01:00
|
|
|
env.open SBDB::Btree, 'newdb.db', :flags => SBDB::CREATE do |db|
|
|
|
|
db.to_hash
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-08-25 13:48:26 +02:00
|
|
|
`SBDB::DB#to_hash` creates a cursor and close it later.
|
|
|
|
|
|
|
|
Tip:
|
|
|
|
|
|
|
|
Signal.trap 'EXIT', env.method( :close)
|