Docs Menu
Docs Home
/ / /
Ruby MongoDB Driver
/

Text Search

MongoDB provides text indexes to support text search queries on string content. Text indexes can include any field whose value is a string or an array of string elements.

Note

MongoDB Atlas also provides Atlas Search which is a more powerful and flexible text search solution. The rest of this page discusses text indexes and not Atlas Search.

To perform a text search with the Ruby driver, first create a text index with indexes.create_one(). The following command creates a text index on the name field of the restaurants collection in the test database.

client = Mongo::Client.new([ '127.0.0.1:27017' ], :database => 'test')
client['restaurants'].indexes.create_one( { :name => 'text' } )

Once the text index is created you can use it as part of a query. The following code finds all documents in the restaurants collection which contain the word garden, without case sensitivity.

client = Mongo::Client.new([ '127.0.0.1:27017' ], :database => 'test')
client[:restaurants].find(
{ '$text' =>
{ '$search' => 'garden', '$caseSensitive' => false }
}
).each do |document|
#=> Yields a BSON::Document.
end

Back

MapReduce