Your SlideShare is downloading. ×
Presentatie
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

Presentatie

848

Published on

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
848
On Slideshare
0
From Embeds
0
Number of Embeds
0
Actions
Shares
0
Downloads
30
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

Transcript

  • 1. Stephan Kaag Internetbureau Holder
  • 2. Internetbureau Holder
  • 3. Agenda • De opdracht • De techniek • De realisatie • Demo • Vragen
  • 4. De opdracht • Het ontwikkelen van een omgeving waarin Ruby on Rails- models weergegeven worden, inclusief de eventuele relaties onderling. • Daarnaast moet het mogelijk zijn om daar real-time wijzigingen in door te voeren.
  • 5. Betty E-mail Relatiebeheer Informatiebeheer Agenda ? Documenten ...
  • 6. De techniek Snel ontwikkelen Veel structuur Goed onderhoudbaar controller Rails: Model - View - Controller model Ruby: “A Programmer’s Best Friend” view
  • 7. ActiveRecord • Database tabel <=> Object • Implementatie van ORM patroon
  • 8. AR versus Hibernate Active- Hibernate Record Migration x Support Minder x Configuratie Eenvoudiger x
  • 9. AR :: Migrations • Log van database- class AddANewTable < ActiveRecord::Migration def self.up wijzigingen create_table :users do |table| table.column :name, :string table.column :login, :string, :null => false • Must in teams table.column :email, :string end end • Productie server met def self.down drop_table :users end dezelfde database end
  • 10. AR :: Conventies • Order wordt orders Class Table Order orders • Primairy key is `id` LineItem line_items Person people Address addresses Legacy legacies • Foreign-key van één kolom Mouse mice Foreign-key is `[parent entity name]_id` Voorbeeld: user_id
  • 11. Een klasse per tabel Een klasse vertegenwoordigt een tabel, een object vertegenwoordigt een rij SQL code Model code class User < ActiveRecord::Base CREATE TABLE `users` ( `id` int(11) NOT NULL auto_increment, end `login` varchar(255) default NULL, `email` varchar(255) default NULL, `updated_at` datetime default NULL, `created_at` datetime default NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=latin1
  • 12. Associatie types • Vier types • has_one class Ticket < ActiveRecord::Base belongs_to :user • belongs_to has_many :comments has_and_belongs_to_many :tags end • has_many • has_and_belongs_to_many
  • 13. Associaties in de praktijk ./app/models/user.rb class User < ActiveRecord::Base belongs_to :group end Laden van een user, met groep >> group_obj = User.find(2).group => #<Group:0x34c207c @attributes={ quot;namequot;=>quot;Vertegenwoordigersquot;, SQL-log quot;idquot;=>quot;2quot;, quot;created_atquot;=>nil}> User load (0.003175) SELECT * FROM users WHERE (users.id = 2) Group load (0.001091) SELECT * FROM groups WHERE (groups.`id` = 1)
  • 14. Realisatie
  • 15. Modificaties • Database wijzigingen met een Migration bijv. extra kolom toevoegen • Model-files uitlezen en aanpassen bijv. model andere naam geven
  • 16. Demo
  • 17. Vragen?

×