1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/lib/arel/visitors/mysql.rb
2011-01-20 00:37:05 -05:00

38 lines
1 KiB
Ruby

module Arel
module Visitors
class MySQL < Arel::Visitors::ToSql
private
def visit_Arel_Nodes_Lock o
if o.locking.is_a?(String)
o.locking
else
"FOR UPDATE"
end
end
###
# :'(
# http://dev.mysql.com/doc/refman/5.0/en/select.html#id3482214
def visit_Arel_Nodes_SelectStatement o
o.limit = Arel::Nodes::Limit.new(18446744073709551615) if o.offset && !o.limit
super
end
def visit_Arel_Nodes_SelectCore o
o.froms ||= Arel.sql('DUAL')
super
end
def visit_Arel_Nodes_UpdateStatement o
[
"UPDATE #{visit o.relation}",
("SET #{o.values.map { |value| visit value }.join ', '}" unless o.values.empty?),
("WHERE #{o.wheres.map { |x| visit x }.join ' AND '}" unless o.wheres.empty?),
("ORDER BY #{o.orders.map { |x| visit x }.join(', ')}" unless o.orders.empty?),
(visit(o.limit) if o.limit),
].compact.join ' '
end
end
end
end