Qu'est-ce que Arel dans Rails 3.0?


86

Je comprends que c'est un remplacement d'ActiveRecord et qu'il utilise des objets au lieu de requêtes.

Mais...

pourquoi est-ce mieux?

les objets / requêtes seront-ils "plus faciles" à créer?

cela conduira-t-il à des requêtes SQL plus efficaces?

sera-t-il compatible avec toutes les principales bases de données? - Je suppose que ce sera le cas.

sera-t-il plus facile / plus difficile à utiliser avec les procédures stockées?

Réponses:


182

Qu'est-ce que Arel dans Rails 3.0?

C'est un modèle objet pour une algèbre d'opérateurs de requêtes relationnelles.

Je comprends qu'il s'agit d'un remplacement d'ActiveRecord

Non, ça ne l'est pas. C'est un remplacement pour les requêtes SQL artisanales dans des chaînes. C'est une couche de requête courante qui sous - tend ActiveRecord, mais elle peut également être utilisée comme sous-jacent pour DataMapper, par exemple.

Si c'est un remplacement pour quoi que ce soit, c'est un remplacement pour Ambition. Ou, vous pouvez le considérer comme une version Ruby des opérateurs de requête standard LINQ ou SQLAlchemy de Python. (En fait, l'auteur cite explicitement LINQ et SQLAlchemy comme inspirations.)

Ou, vous pouvez le voir comme un remplacement de l' named_scopeart. En fait, ARel est à peu près la réalisation de l'idée que "chaque requête est un named_scope". Et, whaddayaknow: les deux ont été écrits par le même gars.

et qu'il utilise des objets au lieu de requêtes.

Non, il utilise des objets comme requêtes.

pourquoi est-ce mieux?

Ruby est un langage orienté objet, pas un langage orienté chaîne. Pour cette seule raison , il est logique de représenter les requêtes sous forme d'objets au lieu de chaînes. Construire un modèle d'objet approprié pour les requêtes au lieu d'utiliser des chaînes pour tout vous offre à peu près les mêmes avantages que la création d'un modèle d'objet approprié pour un système comptable au lieu d'utiliser des chaînes pour tout vous donne.

Un autre gros avantage est qu'ARel implémente une algèbre réelle des opérateurs de requête. En d'autres termes, ARel connaît les règles mathématiques pour construire et composer des requêtes. Si vous concaténez deux chaînes, dont chacune contient une requête SQL valide, le résultat ne sera probablement pas une requête SQL valide. Ou, pire encore, il est une requête SQL valide, mais qui n'a pas de sens, ou qui fait quelque chose de totalement différent de ce que vous pensez. Cela ne peut jamais arriver avec ARel. (C'est ce que signifie l'article auquel je renvoie ci-dessous avec "fermé sous composition".)

les objets / requêtes seront-ils "plus faciles" à créer?

Oui. Par exemple, comme je l'ai mentionné ci-dessus, il est beaucoup plus facile de créer des requêtes plus complexes à partir de parties plus simples.

cela conduira-t-il à des requêtes SQL plus efficaces?

Oui. Le fait qu'ARel dispose d'un modèle d'objet approprié pour les requêtes signifie qu'il peut effectuer des optimisations sur ces requêtes bien avant de générer une requête SQL réelle.

sera-t-il compatible avec toutes les principales bases de données? - Je suppose que ce sera le cas.

Oui. En fait, j'ai toujours parlé de SQL ci-dessus, mais en fait, une algèbre de requête relationnelle peut générer des requêtes pour à peu près tout. Encore une fois, voyez LINQ ou Ambition comme exemples: les deux peuvent interroger SQL, LDAP, ActiveResource, CouchDB, Amazon, Google,… le tout avec la même syntaxe.

Peut-être que la meilleure discussion sur ce qu'est ARel et pourquoi Nick Kallen a écrit est l'article bien nommé Why Arel? par Nick Kallen lui-même. Remarque: l'article contient un jargon mathématique et informatique doux, mais c'est exactement le but: ARel a des bases solides en mathématiques et en informatique, ce sont ces bases qui lui confèrent ses propriétés puissantes.


Excellente réponse. J'avais lu le lien que vous avez posté et je l'ai suivi pour la plupart. En fait, la partie comp sci avait du sens, mais la façon dont elle était incorporée dans les rails était là où j'avais des problèmes. Cela a beaucoup plus de sens pour moi qu'il remplace le SQL fabriqué à la main (ou autre) et donc que l'AR soit construit par-dessus dans la version 3.0. J'avais eu des impressions différentes pour les personnes qui devraient mieux savoir et cette réponse est brillante dans son explication simple et précise de chaque question ci-dessus.
Sera

J'ai une question complémentaire. Vous avez mentionné LDAP, AMZ, etc. ci-dessus, je suppose qu'actuellement (basé sur rails / arel sur github) ARel n'a pas cette capacité, juste le potentiel? c'est-à-dire jusqu'à ce que quelqu'un implémente cette partie. Cela semble super excitant cependant.
Sera

2
@ Will - Je pense que vous allez devoir attendre que quelqu'un développe ces capacités plus funk. Ou essayez-en un vous-même, en avez-vous besoin?
Mike Woodhouse

1
+1, bien que le lien soit mort; la recherche naïve n'a pas trouvé le lien actuel.
Dave Newton

@DaveNewton: Apparemment, c'est parti. Il y a des copies en cache qui flottent, par exemple bmark.us/bmark/readable/913ff84fc0dcdc
Jörg W Mittag

19

ARel, est malheureusement directement lié à la génération de SQL et n'est donc pas adapté aux besoins de DataMapper.

Je dirais que ARel est un modèle de requête explicite pour ActiveRecord qui génère et optimise les requêtes SQL pour les SGBDR.

DataMapper, quant à lui, est un véritable mappeur de données et peut déjà s'interfacer avec des magasins de données non relationnels. À l'avenir, DataMapper inclura probablement une bibliothèque distincte appelée Veritas, qui est destinée à fournir des fonctionnalités relationnelles aux données provenant de N'IMPORTE QUEL magasin de données, pas seulement des SGBDR.


2
Pourquoi cela a-t-il reçu -1?
Jeriko

10
Je suis le mainteneur de DataMapper, et ce que la théorie de la connaissance dit est vrai. ARel, dans son implémentation actuelle, ne peut pas être utilisé sous DataMapper car il ne fournit qu'un sous-ensemble des fonctionnalités nécessaires pour fonctionner avec plus de 40 banques de données prises en charge par DM. À mon humble avis, la mise en œuvre actuelle est étroitement liée à la génération SQL, et il faudra beaucoup de travail pour réparer l'API / les composants internes pour travailler avec des banques de données sensiblement différentes d'un SGBDR. ARel est un pas en avant, mais il ne peut pas constituer une base pour plus qu'ActiveRecord pour le moment.
dkubb

1

Arel dans Rails 3 crée des objets de relation où la base de données n'est pas interrogée jusqu'à ce que vous en ayez besoin. Beaucoup plus efficace.

C'est aussi plus naturel (une fois qu'on s'y est habitué) ce qui est vraiment la grande force des Rails.


0

En fait, j'ai commencé une série de vidéos sur ActiveRelation.

Le premier tutoriel général peut être consulté sur http://Innovative-Studios.com/#pilot


J'ai aussi aimé la vidéo. C'était un peu basique, mais j'ai glané quelques informations supplémentaires. Voudrais voir les vidéos suivantes!
Purplejacket
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.