Sha256: 997762e6d178ca773b9a21da5729fe697dbfc7ee3a2c5be5d2ca87c71d37c65b

Contents?: true

Size: 1.97 KB

Versions: 11

Compression:

Stored size: 1.97 KB

Contents

module Arel
  module Visitors
    class MySQL < Arel::Visitors::ToSql
      private
      def visit_Arel_Nodes_Union o, collector, suppress_parens = false
        unless suppress_parens
          collector << "( "
        end

        collector =   case o.left
                      when Arel::Nodes::Union
                        visit_Arel_Nodes_Union o.left, collector, true
                      else
                        visit o.left, collector
                      end

        collector << " UNION "

        collector =    case o.right
                       when Arel::Nodes::Union
                         visit_Arel_Nodes_Union o.right, collector, true
                       else
                         visit o.right, collector
                       end

        if suppress_parens
          collector
        else
          collector << " )"
        end
      end

      def visit_Arel_Nodes_Bin o, collector
        collector << "BINARY "
        visit o.expr, collector
      end

      ###
      # :'(
      # http://dev.mysql.com/doc/refman/5.0/en/select.html#id3482214
      def visit_Arel_Nodes_SelectStatement o, collector
        if o.offset && !o.limit
          o.limit = Arel::Nodes::Limit.new(18446744073709551615)
        end
        super
      end

      def visit_Arel_Nodes_SelectCore o, collector
        o.froms ||= Arel.sql('DUAL')
        super
      end

      def visit_Arel_Nodes_UpdateStatement o, collector
        collector << "UPDATE "
        collector = visit o.relation, collector

        unless o.values.empty?
          collector << " SET "
          collector = inject_join o.values, collector, ', '
        end

        unless o.wheres.empty?
          collector << " WHERE "
          collector = inject_join o.wheres, collector, ' AND '
        end

        unless o.orders.empty?
          collector << " ORDER BY "
          collector = inject_join o.orders, collector, ', '
        end

        maybe_visit o.limit, collector
      end

    end
  end
end

Version data entries

11 entries across 11 versions & 5 rubygems

Version Path
enju_leaf-1.2.1 vendor/bundle/ruby/2.3/gems/arel-6.0.4/lib/arel/visitors/mysql.rb
arel-6.0.4 lib/arel/visitors/mysql.rb
ish_lib_manager-0.0.1 test/dummy/vendor/bundle/ruby/2.3.0/gems/arel-6.0.3/lib/arel/visitors/mysql.rb
angular-rails4-templates-0.4.1 vendor/ruby/2.1.0/gems/arel-6.0.3/lib/arel/visitors/mysql.rb
angular-rails4-templates-0.4.0 vendor/ruby/2.1.0/gems/arel-6.0.3/lib/arel/visitors/mysql.rb
angular-rails4-templates-0.3.0 vendor/ruby/2.1.0/gems/arel-6.0.3/lib/arel/visitors/mysql.rb
arel-7.0.0 lib/arel/visitors/mysql.rb
sc_core-0.0.7 test/dummy/vendor/bundle/ruby/2.2.0/gems/arel-6.0.3/lib/arel/visitors/mysql.rb
arel-6.0.3 lib/arel/visitors/mysql.rb
arel-6.0.2 lib/arel/visitors/mysql.rb
arel-6.0.1 lib/arel/visitors/mysql.rb