Skip to content

Instantly share code, notes, and snippets.

@SeriouslyAwesome
Last active August 29, 2015 14:21
Show Gist options
  • Save SeriouslyAwesome/1ec3ad92f714758e9b67 to your computer and use it in GitHub Desktop.
Save SeriouslyAwesome/1ec3ad92f714758e9b67 to your computer and use it in GitHub Desktop.
States Migration
# Create a states table with an index on the abbreviation,
# then create the 50 states plus Washington, DC
class CreateStates < ActiveRecord::Migration
def change
create_table :states do |t|
t.string :name, null: false
t.string :abbr, null: false
t.timestamps null: false
end
add_index :states, :abbr
State.reset_column_information
states = {
'AL' => 'Alabama',
'AK' => 'Alaska',
'AZ' => 'Arizona',
'AR' => 'Arkansas',
'CA' => 'California',
'CO' => 'Colorado',
'CT' => 'Connecticut',
'DE' => 'Delaware',
'FL' => 'Florida',
'GA' => 'Georgia',
'HI' => 'Hawaii',
'ID' => 'Idaho',
'IL' => 'Illinois',
'IN' => 'Indiana',
'IA' => 'Iowa',
'KS' => 'Kansas',
'KY' => 'Kentucky',
'LA' => 'Louisiana',
'ME' => 'Maine',
'MD' => 'Maryland',
'MA' => 'Massachusetts',
'MI' => 'Michigan',
'MN' => 'Minnesota',
'MS' => 'Mississippi',
'MO' => 'Missouri',
'MT' => 'Montana',
'NE' => 'Nebraska',
'NV' => 'Nevada',
'NH' => 'New Hampshire',
'NJ' => 'New Jersey',
'NM' => 'New Mexico',
'NY' => 'New York',
'NC' => 'North Carolina',
'ND' => 'North Dakota',
'OH' => 'Ohio',
'OK' => 'Oklahoma',
'OR' => 'Oregon',
'PA' => 'Pennsylvania',
'RI' => 'Rhode Island',
'SC' => 'South Carolina',
'SD' => 'South Dakota',
'TN' => 'Tennessee',
'TX' => 'Texas',
'UT' => 'Utah',
'VT' => 'Vermont',
'VA' => 'Virginia',
'WA' => 'Washington',
'WV' => 'West Virginia',
'WI' => 'Wisconsin',
'WY' => 'Wyoming',
'DC' => 'Washington DC'
}
states.each do |abbr, name|
puts "Creating #{name}..."
State.create!(abbr: abbr, name: name)
puts "...done."
end
end
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment