aboutsummaryrefslogtreecommitdiffstats
path: root/lib/arel/visitors/to_sql.rb
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2010-09-29 13:39:37 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2010-09-29 13:39:37 -0700
commitc8f83d61a113ae3c01005d2ac02e4c17891d918c (patch)
tree1cdd7fef7be6274731dc89569df52a600c4841e0 /lib/arel/visitors/to_sql.rb
parent5ec2fac114b1c70fe7ac87f4767b6f1cbc1e78fc (diff)
parent5ca0c9a45788a14b9f454c93cd24fb0ae12a896b (diff)
downloadrails-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/to_sql.rb')
-rw-r--r--lib/arel/visitors/to_sql.rb14
1 files changed, 14 insertions, 0 deletions
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