Sha256: 0673341883a01a1fe1ecb719e2078944b8810956b78d670401bbb93e11e70164

Contents?: true

Size: 1.39 KB

Versions: 7

Compression:

Stored size: 1.39 KB

Contents

module RedHillConsulting::Core::ActiveRecord::ConnectionAdapters
  # MySQL4-specific behaviors
  module Mysql4Adapter
    def reverse_foreign_keys(table_name, name = nil)
      tables = execute("SHOW TABLES")

      foreign_keys = []
      
      tables.each do |table|
        results = execute("SHOW CREATE TABLE #{table}")
        results.each do |row|
          row[1].lines.each do |line|
            if line =~ /^  CONSTRAINT [`"](.+?)[`"] FOREIGN KEY \([`"](.+?)[`"]\) REFERENCES [`"](.+?)[`"] \((.+?)\)( ON DELETE (.+?))?( ON UPDATE (.+?))?,?$/
              name = $1
              column_names = $2
              references_table_name = $3
              references_column_names = $4
              on_update = $8
              on_delete = $6
              on_update = on_update.downcase.gsub(' ', '_').to_sym if on_update
              on_delete = on_delete.downcase.gsub(' ', '_').to_sym if on_delete

              if references_table_name == table_name
                foreign_keys << ForeignKeyDefinition.new(name,
                                               table, column_names.gsub('`', '').split(', '),
                                               references_table_name, references_column_names.gsub('`', '').split(', '),
                                               on_update, on_delete)
              end
            end
          end
        end
      end

      foreign_keys
    end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
redhillonrails_core-1.0.9.1 lib/red_hill_consulting/core/active_record/connection_adapters/mysql4_adapter.rb
redhillonrails_core-1.0.9 lib/red_hill_consulting/core/active_record/connection_adapters/mysql4_adapter.rb
redhillonrails_core-1.0.8 lib/red_hill_consulting/core/active_record/connection_adapters/mysql4_adapter.rb
redhillonrails_core-1.0.6 lib/red_hill_consulting/core/active_record/connection_adapters/mysql4_adapter.rb
redhillonrails_core-1.0.5 lib/red_hill_consulting/core/active_record/connection_adapters/mysql4_adapter.rb
redhillonrails_core-1.0.4.1 lib/red_hill_consulting/core/active_record/connection_adapters/mysql4_adapter.rb
redhillonrails_core-1.0.4 lib/red_hill_consulting/core/active_record/connection_adapters/mysql4_adapter.rb