aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSylvain Abélard <sylvain.abelard@gmail.com>2017-10-15 20:30:27 +0200
committerGitHub <noreply@github.com>2017-10-15 20:30:27 +0200
commit27a7af81bd274f8036f42638acdb47e85e76c5aa (patch)
tree9a3dda4a2fa13cdd8550612b3625fc279597939d
parent5cc7e774bb4d2190236cdbf46d66c89507ac6933 (diff)
downloadrails-27a7af81bd274f8036f42638acdb47e85e76c5aa.tar.gz
rails-27a7af81bd274f8036f42638acdb47e85e76c5aa.tar.bz2
rails-27a7af81bd274f8036f42638acdb47e85e76c5aa.zip
Update README.md
* s/crazy/advanced/ to avoid ableist words * last sections didn't have titles to separate topics I have written a bit more examples of "less trivial" Arel code here, perhaps we can add some of that here: https://github.com/rstacruz/cheatsheets/pull/92/files
-rw-r--r--README.md5
1 files changed, 4 insertions, 1 deletions
diff --git a/README.md b/README.md
index af768361ab..065bfea26c 100644
--- a/README.md
+++ b/README.md
@@ -188,7 +188,7 @@ users.project(users[:age].average.as("mean_age"))
# => SELECT AVG(users.age) AS mean_age FROM users
```
-### The Crazy Features
+### The Advanced Features
The examples above are fairly simple and other libraries match or come close to matching the expressiveness of Arel (e.g. `Sequel` in Ruby).
@@ -215,6 +215,7 @@ products.
#### Complex Joins
+##### Alias
Where Arel really shines is in its ability to handle complex joins and aggregations. As a first example, let's consider an "adjacency list", a tree represented in a table. Suppose we have a table `comments`, representing a threaded discussion:
```ruby
@@ -240,6 +241,7 @@ comments_with_replies = \
This will return the reply for the first comment.
+##### CTE
[Common Table Expressions (CTE)](https://en.wikipedia.org/wiki/Common_table_expressions#Common_table_expression) support via:
Create a `CTE`
@@ -262,6 +264,7 @@ users.
# FROM users INNER JOIN cte_table ON users.id = cte_table.user_id
```
+#### Write SQL strings
When your query is too complex for `Arel`, you can use `Arel::SqlLiteral`:
```ruby