public
Fork of eladmeidar/rails_indexes
Description: A rake task to track down missing database indexes. does not assume that all foreign keys end with the convention of _id.
Homepage: http://blog.eizesus.com/2009/9/find-where-to-index-your-tables-on-a-rails-app
Clone URL: git://github.com/radar/rails_indexes.git
name age message
file README.textile Loading commit data...
directory lib/
directory spec/
directory tasks/
README.textile

Rails Indexes

Rails indexes is a small package of 2 rake tasks that scan your application models and displays a list of columns that probably should be indexed.

note: there should be mode fields depending on your application design and custom queries.

Installation

as a rails plugin:

script/plugin install git://github.com/eladmeidar/rails_indexes.git

Usage

Display a simple report:

rake db:show_me_some_indexes

Display a migration for adding/removing all necessary indexes based on associations:

rake db:show_me_a_migration

Display a migration for adding/removing all necessary indexes based on AR::Base#find calls (including: find, find_by, find_all_by, find_by_x_and_y, find_all_by_x_and_y):

rake db:show_me_ar_find_indexes

Note that it would probably make more sense running those tasks on production, where you actually need those indexes to be added.

  • Add an option to create a migration that adds all the needed indexes.
  • Add an option to scan the application root tree for #find, #find_all_by and #find_by to get some more index-required columns.

Author:
Elad Meidar
http://blog.eizesus.com

Thanks:
Eric Davis,
http://littlestreamsoftware.com

Released under the same license as Ruby. No Support. No Warranty, no Pain.