Module: SkinnyJeans
- Defined in:
- lib/skinny_jeans.rb,
lib/skinny_jeans/log_parser.rb,
lib/skinny_jeans/string_parser.rb
Overview
example SkinnyJeans::StringParser.extract_search_query(“search.aol.com/aol/search?enabled_terms=&s_it=comsearch50&q=cool+stuff”)
> “cool stuff”
Defined Under Namespace
Classes: LogParser, Pageview, PageviewKeyword, SkinnyJeanDb, StringParser, Update
Class Method Summary collapse
Class Method Details
.prepare_db(sqlite_db_path) ⇒ Object
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 |
# File 'lib/skinny_jeans.rb', line 33 def prepare_db(sqlite_db_path) # create database if necessary SQLite3::Database.new(sqlite_db_path) SkinnyJeanDb.establish_connection(:adapter => 'sqlite3', :database => sqlite_db_path) # create tables if necessary if !Pageview.table_exists? SkinnyJeanDb.connection.create_table(:pageviews) do |t| t.column :date, :date t.column :path, :string t.column :pageview_count, :integer end # flow tight like skinny jeans with these compound indexes SkinnyJeanDb.connection.add_index(:pageviews, [:date, :path], :name => "date_path_index") SkinnyJeanDb.connection.add_index(:pageviews, [:date, :pageview_count], :name => "date_pageview_count_index") end if !Update.table_exists? SkinnyJeanDb.connection.create_table(:updates) do |t| t.column :last_pageview_at, :timestamp t.column :lines_parsed, :integer t.column :last_line_parsed, :string end end # addition from 2010-12-06 to track search traffic specifically if !PageviewKeyword.table_exists? SkinnyJeanDb.connection.create_table(:pageview_keywords) do |t| t.column :date, :date t.column :path, :string t.column :pageview_count, :integer t.column :keyword, :string end SkinnyJeanDb.connection.add_index(:pageview_keywords, [:date, :path, :keyword], :name => "date_path_keyword_index") # SkinnyJeanDb.connection.add_index(:pageview_keywords, [:date, :pageview_count], :name => "date_pageview_count_index") end end |