Your SlideShare is downloading. ×
0
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
ActiveRecord
Upcoming SlideShare
Loading in...5
×

Thanks for flagging this SlideShare!

Oops! An error has occurred.

×
Saving this for later? Get the SlideShare app to save on your phone or tablet. Read anywhere, anytime – even offline.
Text the download link to your phone
Standard text messaging rates apply

ActiveRecord

759

Published on

An overview of ActiveRecord (Rails 3)

An overview of ActiveRecord (Rails 3)

Published in: Technology
0 Comments
0 Likes
Statistics
Notes
  • Be the first to comment

  • Be the first to like this

No Downloads
Views
Total Views
759
On Slideshare
0
From Embeds
0
Number of Embeds
0
Actions
Shares
0
Downloads
11
Comments
0
Likes
0
Embeds 0
No embeds

Report content
Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
No notes for slide
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • \n
  • Transcript

    • 1. ACTIVERECORD Rails 3
    • 2. MVC
    • 3. MODEL CLASSin app/models/person.rbclass Message < ActiveRecord::Baseend
    • 4. EVERY MODEL HASA CORRESPONDING DATABASE TABLE
    • 5. MVC
    • 6. HOW DID WE GETA DATABASE TABLE?
    • 7. RUBY-DRIVEN SCHEMA• scaffold generates db/migrate/20110131021702_create_people.rb• rake db:migrate runs the migration, creates the table• Watch what we did before in slow motion...
    • 8. DEMO
    • 9. RAILS CONSOLE>> ActiveRecord::Base.logger = Logger.new(STDOUT)
    • 10. RAILS CONSOLE>> ActiveRecord::Base.logger = Logger.new(STDOUT)>> Person.first SQL (1.0ms) SELECT nameFROM sqlite_masterWHERE type = table AND NOT name = sqlite_sequence Person Load (1.0ms) SELECT "people".* FROM "people" LIMIT 1=> #<Person id: 2, first_name: "Wilma", last_name: "Flinstone", created_at: "2010-10-19 19:59:36", updated_at: "2010-10-19 19:59:36">
    • 11. RAILS CONSOLE>> ActiveRecord::Base.logger = Logger.new(STDOUT)>> Person.first SQL (1.0ms) SELECT nameFROM sqlite_masterWHERE type = table AND NOT name = sqlite_sequence Person Load (1.0ms) SELECT "people".* FROM "people" LIMIT 1=> #<Person id: 2, first_name: "Wilma", last_name: "Flinstone", created_at: "2010-10-19 19:59:36", updated_at: "2010-10-19 19:59:36"> find "people" table name
    • 12. RAILS CONSOLE>> ActiveRecord::Base.logger = Logger.new(STDOUT)>> Person.first SQL (1.0ms) SELECT nameFROM sqlite_masterWHERE type = table AND NOT name = sqlite_sequence Person Load (1.0ms) SELECT "people".* FROM "people" LIMIT 1=> #<Person id: 2, first_name: "Wilma", last_name: "Flinstone", created_at: "2010-10-19 19:59:36", updated_at: "2010-10-19 19:59:36"> find first row in "people table"
    • 13. DYNAMIC GETTERS AND SETTERS>> bret = Person.new>> bret.first_name = "Bret">> bret.last_name = "Smith">> bret.first_name"Bret">> bret.xxxNoMethodError
    • 14. MORE ACTIVE RECORD• save to database as needed• automatically handle update/insert• dynamic queries
    • 15. SQL INJECTION
    • 16. SAFE FROM SQL INJECTIONclass User < ActiveRecord::Base def self.authenticate_unsafely(user_name, password) find(:first, :conditions => "user_name = #{user_name} AND password = #{password}") end def self.authenticate_safely(user_name, password) find(:first, :conditions => [ "user_name = ? AND password = ?", user_name, password ]) end def self.authenticate_safely_simply(user_name, password) find(:first, :conditions => { :user_name => user_name, :password => password }) end
    • 17. QUESTIONS?

    ×