[Gary] Editing due to minor disconnects of a newbie - might as well make improvements before I'm too tainted by familiarity. Any suggestions for a GFM previewer?

This commit is contained in:
Gary Murakami 2012-04-02 17:25:01 -04:00
parent d4efbe96f7
commit 9e47109b8f

View File

@ -9,8 +9,11 @@ As always, the [latest source for the Ruby driver](http://github.com/mongodb/mon
## Installation ## Installation
The mongo-ruby-driver gem is served through Rubygems.org. To install, make sure you have the latest version of rubygems. The mongo-ruby-driver gem is served through Rubygems.org. To install, make sure you have the latest version of rubygems.
gem update --system gem update --system
Next, install the mongo rubygem: Next, install the mongo rubygem:
gem install mongo gem install mongo
The required `bson` gem will be installed automatically. The required `bson` gem will be installed automatically.
@ -32,27 +35,33 @@ All of the code here assumes that you have already executed the following Ruby c
#### Making a Connection #### Making a Connection
An `Mongo::Connection` instance represents a connection to MongoDB. You use a Connection instance to obtain an Mongo:DB instance, which represents a named database. The database doesn't have to exist - if it doesn't, MongoDB will create it for you. An `Mongo::Connection` instance represents a connection to MongoDB. You can optionally specify the MongoDB server address and port when connecting. The following example shows three ways to connect to the local machine:
You can optionally specify the MongoDB server address and port when connecting. The following example shows three ways to connect to the database "mydb" on the local machine: connection = Mongo::Connection.new # (optional host/port args)
connection = Mongo::Connection.new("localhost")
db = Mongo::Connection.new.db("mydb") connection = Mongo::Connection.new("localhost", 27017)
db = Mongo::Connection.new("localhost").db("mydb")
db = Mongo::Connection.new("localhost", 27017).db("mydb")
At this point, the `db` object will be a connection to a MongoDB server for the specified database. Each DB instance uses a separate socket connection to the server.
If you're trying to connect to a replica set, see [Replica Sets in Ruby](http://www.mongodb.org/display/DOCS/Replica+Sets+in+Ruby).
#### Listing All Databases #### Listing All Databases
connection = Mongo::Connection.new # (optional host/port args)
connection.database_names.each { |name| puts name } connection.database_names.each { |name| puts name }
connection.database_info.each { |info| puts info.inspect} connection.database_info.each { |info| puts info.inspect}
#### Dropping a Database #### Dropping a Database
connection.drop_database('database_name') connection.drop_database('database_name')
#### Using a Database
You use a Connection instance to obtain an Mongo:DB instance, which represents a named database. The database doesn't have to exist - if it doesn't, MongoDB will create it for you. The following examples use the database "mydb":
db = connection.db("mydb")
db = Mongo::Connection.new.db("mydb")
At this point, the `db` object will be a connection to a MongoDB server for the specified database. Each DB instance uses a separate socket connection to the server.
If you're trying to connect to a replica set, see [Replica Sets in Ruby](http://www.mongodb.org/display/DOCS/Replica+Sets+in+Ruby).
#### Authentication
MongoDB can be run in a secure mode where access to databases is controlled through name and password authentication. When run in this mode, any client application must provide a name and password before doing any operations. In the Ruby driver, you simply do the following with the connected mongo object: MongoDB can be run in a secure mode where access to databases is controlled through name and password authentication. When run in this mode, any client application must provide a name and password before doing any operations. In the Ruby driver, you simply do the following with the connected mongo object:
auth = db.authenticate(my_user_name, my_password) auth = db.authenticate(my_user_name, my_password)
@ -75,8 +84,11 @@ as the output.
#### Getting a Collection #### Getting a Collection
You can get a collection to use using the `collection` method: You can get a collection to use using the `collection` method:
coll = db.collection("testCollection") coll = db.collection("testCollection")
This is aliased to the \[\] method: This is aliased to the \[\] method:
coll = db["testCollection"] coll = db["testCollection"]
Once you have this collection object, you can now do things like insert data, query for data, etc. Once you have this collection object, you can now do things like insert data, query for data, etc.