updated word count example
This commit is contained in:
parent
a4144af72d
commit
50f0104173
3 changed files with 11 additions and 32 deletions
|
@ -6,8 +6,7 @@ which I find to be concise, clear, and well designed. CouchRest lightly wraps
|
||||||
CouchDB's HTTP API, managing JSON serialization, and remembering the URI-paths
|
CouchDB's HTTP API, managing JSON serialization, and remembering the URI-paths
|
||||||
to CouchDB's API endpoints so you don't have to.
|
to CouchDB's API endpoints so you don't have to.
|
||||||
|
|
||||||
CouchRest's lighweight is designed to make a simple base for application and
|
CouchRest is designed to make a simple base for application and framework-specific object oriented APIs. CouchRest is Object-Mapper agnostic, the parsed JSON it returns from CouchDB shows up as subclasses of Ruby's Hash. Naked JSON, just as it was mean to be.
|
||||||
framework-specific object oriented APIs.
|
|
||||||
|
|
||||||
## Easy Install
|
## Easy Install
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
require File.dirname(__FILE__) + '/../../couchrest'
|
require 'rubygems'
|
||||||
|
require 'couchrest'
|
||||||
|
|
||||||
couch = CouchRest.new("http://127.0.0.1:5984")
|
couch = CouchRest.new("http://127.0.0.1:5984")
|
||||||
db = couch.database('word-count-example')
|
db = couch.database('word-count-example')
|
||||||
|
@ -39,29 +40,7 @@ books.keys.each do |book|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# word_count = {
|
|
||||||
# :map => 'function(doc){
|
|
||||||
# var words = doc.text.split(/\W/);
|
|
||||||
# words.forEach(function(word){
|
|
||||||
# if (word.length > 0) emit([word,doc.title],1);
|
|
||||||
# });
|
|
||||||
# }',
|
|
||||||
# :reduce => 'function(key,combine){
|
|
||||||
# return sum(combine);
|
|
||||||
# }'
|
|
||||||
# }
|
|
||||||
#
|
|
||||||
# db.delete db.get("_design/word_count") rescue nil
|
|
||||||
#
|
|
||||||
# db.save({
|
|
||||||
# "_id" => "_design/word_count",
|
|
||||||
# :views => {
|
|
||||||
# :count => word_count,
|
|
||||||
# :words => {:map => word_count[:map]}
|
|
||||||
# }
|
|
||||||
# })
|
|
||||||
|
|
||||||
# puts "The books have been stored in your CouchDB. To initiate the MapReduce process, visit http://127.0.0.1:5984/_utils/ in your browser and click 'word-count-example', then select view 'words' or 'count'. The process could take about 15 minutes on an average MacBook."
|
# puts "The books have been stored in your CouchDB. To initiate the MapReduce process, visit http://127.0.0.1:5984/_utils/ in your browser and click 'word-count-example', then select view 'words' or 'count'. The process could take about 15 minutes on an average MacBook."
|
||||||
#
|
|
||||||
|
|
||||||
|
|
|
@ -1,22 +1,23 @@
|
||||||
require File.dirname(__FILE__) + '/../../couchrest'
|
require 'rubygems'
|
||||||
|
require 'couchrest'
|
||||||
|
|
||||||
couch = CouchRest.new("http://127.0.0.1:5984")
|
couch = CouchRest.new("http://127.0.0.1:5984")
|
||||||
db = couch.database('word-count-example')
|
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 "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:"
|
puts "\nThe simplest query we can run is the total word count for all words in all documents:"
|
||||||
|
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/count').inspect
|
puts db.view('word_count/words').inspect
|
||||||
|
|
||||||
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:"
|
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:"
|
||||||
|
|
||||||
word = 'flight'
|
word = 'flight'
|
||||||
params = {
|
params = {
|
||||||
:startkey => [word],
|
:startkey => [word],
|
||||||
:endkey => [word,'Z']
|
:endkey => [word,{}]
|
||||||
}
|
}
|
||||||
|
|
||||||
puts db.view('word_count/count',params).inspect
|
puts db.view('word_count/words',params).inspect
|
||||||
|
|
||||||
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 "\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 params.inspect
|
||||||
|
@ -28,7 +29,7 @@ params = {
|
||||||
:key => [word, title]
|
:key => [word, title]
|
||||||
}
|
}
|
||||||
|
|
||||||
puts db.view('word_count/count',params).inspect
|
puts db.view('word_count/words',params).inspect
|
||||||
|
|
||||||
|
|
||||||
puts "\nHere are the params for 'flight' in the da-vinci book:"
|
puts "\nHere are the params for 'flight' in the da-vinci book:"
|
||||||
|
|
Loading…
Reference in a new issue