diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2010-09-29 13:39:37 -0700 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2010-09-29 13:39:37 -0700 |
commit | c8f83d61a113ae3c01005d2ac02e4c17891d918c (patch) | |
tree | 1cdd7fef7be6274731dc89569df52a600c4841e0 /lib/arel/visitors | |
parent | 5ec2fac114b1c70fe7ac87f4767b6f1cbc1e78fc (diff) | |
parent | 5ca0c9a45788a14b9f454c93cd24fb0ae12a896b (diff) | |
download | rails-c8f83d61a113ae3c01005d2ac02e4c17891d918c.tar.gz rails-c8f83d61a113ae3c01005d2ac02e4c17891d918c.tar.bz2 rails-c8f83d61a113ae3c01005d2ac02e4c17891d918c.zip |
Merge remote branch 'ernie/master'
* ernie/master:
Make PostgreSQL play nice with its friends. (matches -> ILIKE instead of LIKE)
Add support for remaining *_any/*_all attribute methods, and add matches/does_not_match/not_in
Add eq_any.
Diffstat (limited to 'lib/arel/visitors')
-rw-r--r-- | lib/arel/visitors/postgresql.rb | 8 | ||||
-rw-r--r-- | lib/arel/visitors/to_sql.rb | 14 |
2 files changed, 22 insertions, 0 deletions
diff --git a/lib/arel/visitors/postgresql.rb b/lib/arel/visitors/postgresql.rb index 87fc3bd60d..5e03f40984 100644 --- a/lib/arel/visitors/postgresql.rb +++ b/lib/arel/visitors/postgresql.rb @@ -21,6 +21,14 @@ module Arel end end + def visit_Arel_Nodes_Matches o + "#{visit o.left} ILIKE #{visit o.right}" + end + + def visit_Arel_Nodes_DoesNotMatch o + "#{visit o.left} NOT ILIKE #{visit o.right}" + end + def using_distinct_on?(o) o.cores.any? do |core| core.projections.any? do |projection| diff --git a/lib/arel/visitors/to_sql.rb b/lib/arel/visitors/to_sql.rb index fc821a0ddb..7f9186d28c 100644 --- a/lib/arel/visitors/to_sql.rb +++ b/lib/arel/visitors/to_sql.rb @@ -161,6 +161,14 @@ module Arel "#{visit o.left} < #{visit o.right}" end + def visit_Arel_Nodes_Matches o + "#{visit o.left} LIKE #{visit o.right}" + end + + def visit_Arel_Nodes_DoesNotMatch o + "#{visit o.left} NOT LIKE #{visit o.right}" + end + def visit_Arel_Nodes_StringJoin o "#{visit o.left} #{visit o.right}" end @@ -191,6 +199,12 @@ module Arel "#{visit o.left} IN (#{right})" end + def visit_Arel_Nodes_NotIn o + right = o.right + right = right.empty? ? 'NULL' : right.map { |x| visit x }.join(', ') + "#{visit o.left} NOT IN (#{right})" + end + def visit_Arel_Nodes_And o "#{visit o.left} AND #{visit o.right}" end |