1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/activerecord/lib/arel/nodes/insert_statement.rb
Ryuta Kamizono 6e43a207c6 Revert unused code and re-using query annotation for update_all and delete_all
This partly reverts #35617.

#35617 includes unused code (for `InsertStatement`) and re-using query
annotation for `update_all` and `delete_all`, which has not been
discussed yet.

If a relation has any annotation, I think it is mostly for SELECT query,
so re-using annotation by default is not always desired behavior for me.

We should discuss about desired behavior before publishing the
implementation.
2019-04-01 15:04:11 +09:00

37 lines
855 B
Ruby

# frozen_string_literal: true
module Arel # :nodoc: all
module Nodes
class InsertStatement < Arel::Nodes::Node
attr_accessor :relation, :columns, :values, :select
def initialize
super()
@relation = nil
@columns = []
@values = nil
@select = nil
end
def initialize_copy(other)
super
@columns = @columns.clone
@values = @values.clone if @values
@select = @select.clone if @select
end
def hash
[@relation, @columns, @values, @select].hash
end
def eql?(other)
self.class == other.class &&
self.relation == other.relation &&
self.columns == other.columns &&
self.select == other.select &&
self.values == other.values
end
alias :== :eql?
end
end
end