Ruby on Rails - Enregistrements actifs

L'enregistrement actif Rails est la couche ORM (Object / Relational Mapping) fournie avec Rails. Il suit de près le modèle ORM standard, qui est le suivant -

  • les tables correspondent aux classes,
  • les lignes correspondent aux objets et
  • les colonnes correspondent aux attributs d'objet.

Les enregistrements actifs de Rails fournissent une interface et une liaison entre les tables d'une base de données relationnelle et le code de programme Ruby qui manipule les enregistrements de la base de données. Les noms de méthode Ruby sont automatiquement générés à partir des noms de champ des tables de base de données.

Chaque objet Active Record a CRUD (Ccréer, Read, Update, et Delete) méthodes d'accès à la base de données. Cette stratégie permet des conceptions simples et des mappages directs entre les tables de base de données et les objets d'application.

Traduire un modèle de domaine en SQL

La traduction d'un modèle de domaine en SQL est généralement simple, tant que vous vous souvenez que vous devez écrire du SQL compatible Rails. Concrètement, vous devez suivre certaines règles -

  • Chaque entité (comme un livre) obtient une table dans la base de données qui porte son nom, mais au pluriel (livres).

  • Chacune de ces tables de correspondance d'entités a un champ appelé id , qui contient un entier unique pour chaque enregistrement inséré dans la table.

  • Étant donné l'entité x et l'entité y, si l'entité y appartient à l'entité x, alors la table y a un champ appelé x_id.

  • La majorité des champs de n'importe quelle table stockent les valeurs des propriétés simples de cette entité (tout ce qui est un nombre ou une chaîne).

Création de fichiers d'enregistrement actifs (modèles)

Pour créer les fichiers Active Record pour nos entités pour l'application de bibliothèque, introduits dans le chapitre précédent, exécutez la commande suivante à partir du niveau supérieur du répertoire de l'application.

library\> rails script/generate model Book
library\> rails script/generate model Subject

Au dessus de rails generate model book commandes génère le code automatique comme ci-dessous -

Vous dites au générateur de créer des modèles appelés Livre et Sujet pour stocker des instances de livres et de sujets. Notez que vous mettez en majuscule Livre et Sujet et utilisez la forme singulière. Il s'agit d'un paradigme Rails que vous devez suivre chaque fois que vous créez un modèle.

Lorsque vous utilisez l'outil de génération, Rails crée le fichier de modèle réel contenant toutes les méthodes propres au modèle et les règles métier que vous définissez, un fichier de test unitaire pour effectuer un développement piloté par les tests, un exemple de fichier de données (appelé fixtures) à utiliser avec les tests unitaires et une migration Rails qui facilite la création de tables et de colonnes de base de données.

Outre la création de nombreux autres fichiers et répertoires, cela créera des fichiers nommés book.rb et subject.rb contenant une définition de squelette dans le app/models annuaire.

Contenu disponible dans book.rb -

class Book < ActiveRecord::Base
end

Contenu disponible dans subject.rb -

class Subject < ActiveRecord::Base
end

Création d'associations entre modèles

Lorsque vous avez plus d'un modèle dans votre application de rails, vous devez créer une connexion entre ces modèles. Vous pouvez le faire via des associations. Active Record prend en charge trois types d'associations -

  • one-to-one- Une relation un-à-un existe lorsqu'un élément a exactement un élément d'un autre. Par exemple, une personne a exactement un anniversaire ou un chien a exactement un propriétaire.

  • one-to-many- Une relation un-à-plusieurs existe lorsqu'un seul objet peut être membre de nombreux autres objets. Par exemple, un sujet peut avoir plusieurs livres.

  • many-to-many - Une relation plusieurs-à-plusieurs existe lorsque le premier objet est lié à un ou plusieurs d'un deuxième objet et que le deuxième objet est lié à un ou plusieurs des premiers objets.

Vous indiquez ces associations en ajoutant des déclarations à vos modèles: has_one, has_many, comes_to et has_and_belongs_to_many.

Vous devez maintenant indiquer à Rails les relations que vous souhaitez établir dans le système de données de la bibliothèque. Pour ce faire, modifiez book.rb et subject.rb pour qu'ils ressemblent à ceci -

class Book < ActiveRecord::Base
   belongs_to :subject
end

Nous avons utilisé un sujet singulier dans l'exemple ci-dessus, car un livre peut appartenir à un seul sujet.

class Subject < ActiveRecord::Base
   has_many :books
end

Nous avons utilisé plusieurs livres ici, car un sujet peut avoir plusieurs livres.

Implémentation de validations sur des modèles

L'implémentation des validations se fait dans un modèle Rails. Les données que vous entrez dans la base de données sont définies dans le modèle Rails réel, il est donc logique de définir ce que les données valides impliquent au même emplacement.

Les validations sont -

  • La valeur du champ de titre ne doit pas être NULL.
  • La valeur du champ de prix doit être numérique.

Ouvert book.rb dans le app\model sous-répertoire et mettez les validations suivantes -

class Book < ActiveRecord::Base
   belongs_to :subject
   validates_presence_of :title
   validates_numericality_of :price, :message=>"Error Message"
end
  • validates_presence_of - protège les champs "NOT NULL" contre les entrées utilisateur manquantes.

  • validates_numericality_of - empêche l'utilisateur de saisir des données non numériques.

Outre les validations mentionnées ci-dessus, il existe d'autres validations communes. Consultez le guide rapide des rails .

Quelle est la prochaine?

Dans le chapitre suivant, nous allons apprendre Rails Migration, qui vous permet d'utiliser Ruby pour définir les modifications de votre schéma de base de données, ce qui permet d'utiliser un système de contrôle de version pour garder les choses synchronisées avec le code réel.