日期:2014-05-16  浏览次数:20364 次

[转]Ruby连接MongoDB

Ruby连接MongoDB

想要在Ruby中连接MongoDB,需要使用mongo模块,该模块可以通过ruby自带的gems程序进行安装。

$ gem update --system
$ gem install mongo
$ gem install bson_ext

Mongo模块提供了Mongo::Connnection类连接MongoDB,如果不指定具体的数据库,默认情况下会创建一个持有MongoDB连接的实例,

require 'mongo'
conn = Mongo::Connection.new
puts conn.class            # Mongo::Connection
puts conn.database_names   # ["admin", "local", ...]

如果需要指定默认的数据库,可以在创建实例的时候指定。如果指定的数据库不存在,MongoDB会创建该数据库。

db = Mongo::Connection.new.db('blog')
db.create_collection('users')  # 创建一个collection
puts db.class                  # Mongo::DB

涉及数据库的操作,基本的创建、删除、拷贝、重命名。重命名操作可以通过拷贝和删除组合完成。

conn.copy_database('blog', 'blog-backup')
conn.drop_database('blog-backup')

在MongoDB中没有了表的概念,取而代之的是collection,可以理解为容器,记录全都存放在collection中。对collection所能做的也是传统的CRUD操作,不过使用起来更加面向对象。Mongo模块的Collection类提供了insert, drop, update, find等方法操作collection。下面大概地了解一下它们的用法。

在先前创建的名为users的collection中插入几条记录。MongoDB中记录的类型为类JSON格式,形式如下。

{ 
  "_id" : ObjectId("4d51eb216b6f45122c000001"), 
  "username" : "clovery", 
  "password" : "clovery" 
}
# ruby中无法识别json格式,所以插入记录时使用ruby的hash格式,mongo模块会自动转换成json形式
# 向users中插入三条记录
db['users'].insert({"username" => "andy", "password" => "12345"})
db['users'].insert({"username" => "alien", "password" => "12345"})
db['users'].insert({"username" => "angel", "password" => "12345"})

db['users'].count  # 3

可以通过find_one和find检索记录。find_one返回一个BSON::OrderedHash数据,类似于ruby的hash类型。find返回Mongo::Cursor引用,可以 对其进行迭代检索所有符合条件的数据。

db['users'].find_one   
# {"_id"=>BSON::ObjectId('4d5246c26b6f451714000004'), "username"=>"andy", "password"=>"12345"}

db['users'].find.each do |row|
  print "#{row['username']} "
end
# andy alien angel

update可以更新原有的记录。

db['users'].update({'username' => 'andy'}, {'$set' => {'password' => 'andy'}})
# {"_id"=>BSON::ObjectId('4d52499d6b6f451714000008'), "password"=>"andy", "username"=>"andy"}

使用remove删除collection中的记录,如果不指定条件,会删除collection中的所有记录。

db['users'].remove({'username' => 'andy'}) 
db['users'].count # 2

删除collection