Module: ActiveRecord::Import::MysqlAdapter
- Includes:
- ImportSupport, OnDuplicateKeyUpdateSupport
- Defined in:
- lib/activerecord-import/adapters/mysql_adapter.rb
Instance Method Summary collapse
-
#duplicate_key_update_error?(exception) ⇒ Boolean
return true if the statement is a duplicate key record error.
-
#max_allowed_packet ⇒ Object
Returns the maximum number of bytes that the server will allow in a single packet.
-
#sql_for_on_duplicate_key_update(table_name, *args) ⇒ Object
Returns a generated ON DUPLICATE KEY UPDATE statement given the passed in
args
. -
#sql_for_on_duplicate_key_update_as_array(table_name, arr) ⇒ Object
:nodoc:.
-
#sql_for_on_duplicate_key_update_as_hash(table_name, hsh) ⇒ Object
:nodoc:.
Methods included from OnDuplicateKeyUpdateSupport
#supports_on_duplicate_key_update?
Methods included from ImportSupport
Instance Method Details
#duplicate_key_update_error?(exception) ⇒ Boolean
return true if the statement is a duplicate key record error
50 51 52 |
# File 'lib/activerecord-import/adapters/mysql_adapter.rb', line 50 def duplicate_key_update_error?(exception)# :nodoc: exception.is_a?(ActiveRecord::StatementInvalid) && exception.to_s.include?('Duplicate entry') end |
#max_allowed_packet ⇒ Object
Returns the maximum number of bytes that the server will allow in a single packet
7 8 9 10 11 12 |
# File 'lib/activerecord-import/adapters/mysql_adapter.rb', line 7 def max_allowed_packet # :nodoc: result = execute( "SHOW VARIABLES like 'max_allowed_packet';" ) # original Mysql gem responds to #fetch_row while Mysql2 responds to #first val = result.respond_to?(:fetch_row) ? result.fetch_row[1] : result.first[1] val.to_i end |
#sql_for_on_duplicate_key_update(table_name, *args) ⇒ Object
Returns a generated ON DUPLICATE KEY UPDATE statement given the passed in args
.
16 17 18 19 20 21 22 23 24 25 26 27 28 29 |
# File 'lib/activerecord-import/adapters/mysql_adapter.rb', line 16 def sql_for_on_duplicate_key_update( table_name, *args ) # :nodoc: sql = ' ON DUPLICATE KEY UPDATE ' arg = args.first if arg.is_a?( Array ) sql << sql_for_on_duplicate_key_update_as_array( table_name, arg ) elsif arg.is_a?( Hash ) sql << sql_for_on_duplicate_key_update_as_hash( table_name, arg ) elsif arg.is_a?( String ) sql << arg else raise ArgumentError.new( "Expected Array or Hash" ) end sql end |
#sql_for_on_duplicate_key_update_as_array(table_name, arr) ⇒ Object
:nodoc:
31 32 33 34 35 36 37 |
# File 'lib/activerecord-import/adapters/mysql_adapter.rb', line 31 def sql_for_on_duplicate_key_update_as_array( table_name, arr ) # :nodoc: results = arr.map do |column| qc = quote_column_name( column ) "#{table_name}.#{qc}=VALUES(#{qc})" end results.join( ',' ) end |
#sql_for_on_duplicate_key_update_as_hash(table_name, hsh) ⇒ Object
:nodoc:
39 40 41 42 43 44 45 46 47 |
# File 'lib/activerecord-import/adapters/mysql_adapter.rb', line 39 def sql_for_on_duplicate_key_update_as_hash( table_name, hsh ) # :nodoc: sql = ' ON DUPLICATE KEY UPDATE ' results = hsh.map do |column1, column2| qc1 = quote_column_name( column1 ) qc2 = quote_column_name( column2 ) "#{table_name}.#{qc1}=VALUES( #{qc2} )" end results.join( ',') end |