couchrest_model/examples/word_count/word_count_query.rb

40 lines
1.3 KiB
Ruby
Raw Normal View History

2009-01-15 15:05:55 -08:00
require 'rubygems'
require 'couchrest'
2008-05-25 11:49:37 -07:00
2008-12-14 12:05:02 +01:00
couch = CouchRest.new("http://127.0.0.1:5984")
2008-05-25 11:49:37 -07:00
db = couch.database('word-count-example')
puts "Now that we've parsed all those books into CouchDB, the queries we can run are incredibly flexible."
puts "\nThe simplest query we can run is the total word count for all words in all documents:"
2009-01-15 15:05:55 -08:00
puts "this will take a few minutes the first time. if it times out, just rerun this script in a few few minutes."
puts db.view('word_count/words').inspect
2008-05-25 11:49:37 -07:00
2008-05-25 22:35:04 -07:00
puts "\nWe can also narrow the query down to just one word, across all documents. Here is the count for 'flight' in all three books:"
2008-05-25 11:49:37 -07:00
word = 'flight'
params = {
:startkey => [word],
2009-01-15 15:05:55 -08:00
:endkey => [word,{}]
2008-05-25 11:49:37 -07:00
}
2009-01-15 15:05:55 -08:00
puts db.view('word_count/words',params).inspect
2008-05-25 11:49:37 -07:00
puts "\nWe scope the query using startkey and endkey params to take advantage of CouchDB's collation ordering. Here are the params for the last query:"
puts params.inspect
puts "\nWe can also count words on a per-title basis."
2008-05-25 22:35:04 -07:00
2008-05-25 11:49:37 -07:00
title = 'da-vinci'
params = {
:key => [word, title]
}
2008-05-25 22:35:04 -07:00
2009-01-15 15:05:55 -08:00
puts db.view('word_count/words',params).inspect
2008-05-25 22:35:04 -07:00
2008-05-25 11:49:37 -07:00
puts "\nHere are the params for 'flight' in the da-vinci book:"
puts params.inspect
puts
puts 'The url looks like this:'
2008-12-14 12:05:02 +01:00
puts 'http://127.0.0.1:5984/word-count-example/_view/word_count/count?key=["flight","da-vinci"]'
2008-05-25 11:49:37 -07:00
puts "\nTry dropping that in your browser..."