aboutsummaryrefslogtreecommitdiffstats
path: root/railties/guides
diff options
context:
space:
mode:
authorRyan Bigg <radarlistener@gmail.com>2010-12-23 18:36:39 +1000
committerRyan Bigg <radarlistener@gmail.com>2010-12-23 18:36:39 +1000
commit8713bb6ab8ff5acf60872b0b8f0bffd13a0aa1ca (patch)
treeb96cbc4bccd8380dd812c397ab5f962e62850395 /railties/guides
parent6271f3f16b5b9c6d60ba7d758d2b595be8074e00 (diff)
downloadrails-8713bb6ab8ff5acf60872b0b8f0bffd13a0aa1ca.tar.gz
rails-8713bb6ab8ff5acf60872b0b8f0bffd13a0aa1ca.tar.bz2
rails-8713bb6ab8ff5acf60872b0b8f0bffd13a0aa1ca.zip
Query guide: cover further ARel methods
Diffstat (limited to 'railties/guides')
-rw-r--r--railties/guides/source/active_record_querying.textile83
1 files changed, 76 insertions, 7 deletions
diff --git a/railties/guides/source/active_record_querying.textile b/railties/guides/source/active_record_querying.textile
index 1bd9ec7972..8eb28ec953 100644
--- a/railties/guides/source/active_record_querying.textile
+++ b/railties/guides/source/active_record_querying.textile
@@ -355,38 +355,107 @@ The +eq+ method can be used to check if a field is a specific value:
Post.where(Post.arel_table[:comments_count].eq(5))
</ruby>
+This method's opposite is +not_eq+.
+
h4. +eq_any+
-The +eq_any+ method can be used to return objects of a relation that have the specified field matching any of the specified values.
+Checks if the specified field matches any of the given values.
<ruby>
Post.where(Post.arel_table[:comments_count].eq_any([1,2])
</ruby>
+This method's opposite is +not_eq_any+.
+
h4. +in+
-To check if a value is within a given group of values, use the +in+ method:
+To check if a field is within a given group of values, use the +in+ method:
<ruby>
- Post.where(Post.arel_table[:id].in([1,2,3]))
+Post.where(Post.arel_table[:id].in([1,2,3]))
</ruby>
+This method's opposite is +not_in+.
+
h4. +in_any+
-Check if a value is within any one of a group of values:
+Check if a field is within any one of a group of values:
<ruby>
- Post.where(Post.arel_table[:id]).in_any([1,2,3], [4,5,6])
+Post.where(Post.arel_table[:id]).in_any([1,2,3], [4,5,6])
</ruby>
+This method's opposite is +not_in_any+.
+
h4. +in_all+
-Check if a value is within all of the specified groups of values:
+Check if a field is within all of the specified groups of values:
+
+<ruby>
+Post.where(Post.arel_table[:id]).in_all([1,2,3], [1,4,6])
+</ruby>
+
+This method's opposite is +not_in_all+.
+
+h4. +matches+
+
+Match a specific field with a given value. Use +%+ for wildcard searching.
+
+<ruby>
+Post.where(Post.arel_table[:author].matches("Ryan%"))
+</ruby>
+
+This method's opposite is +does_not_match+.
+
+h4. +matches_any+
+
+Match a specific field with any given value. Use +%+ for wildcard searching.
+
+<ruby>
+Post.where(Post.arel_table[:author].matches_any(["Ryan%", "Yehuda%"]))
+</ruby>
+
+This method's opposite is +does_not_match_any+
+
+h4. +matches_all+
+
+Match a specific field with all given values. Use +%+ for wild card searching.
+
+<ruby>
+Post.where(Post.arel_table[:author].matches_all(["Ryan%", "%Bigg"]))
+</ruby>
+
+This method's opposite is +does_not_match_all+.
+
+h4. +gteq+
+
+Check for a field greater than or equal to a specific value.
+
+<ruby>
+Post.where(Post.arel_table[:comments_count].gteq(1))
+</ruby>
+
+This method's opposite is +lteq+.
+
+h4. +gteq_any+
+
+Check for a field greater than or equal to any of the given values.
+
+<ruby>
+Post.where(Post.arel_table[:comments_count].gteq_any([1,2]))
+</ruby>
+
+This method's opposite is +lteq_any+.
+
+h4. +gteq_all+
+
+Check for a field greater than or equal to all of the given values.
<ruby>
- Post.where(Post.arel_table[:id]).in_all([1,2,3], [1,4,6])
+Post.where(Post.arel_table[:comments_count].gteq_all([1,2]))
</ruby>
+This method's opposite is +lteq_all+.
h3. Ordering