Sha256: 3bd6a83c23fcbe54cfb03cf1e1ac3558447f79efe77c1b14505b71fd415edb7c
Contents?: true
Size: 1.25 KB
Versions: 2
Compression:
Stored size: 1.25 KB
Contents
# frozen_string_literal: true module TableSaw module Queries class ForeignKeyRelationships QUERY = <<~SQL select tc.table_name as from_table, kcu.column_name as from_column, ccu.table_name as to_table, ccu.column_name as to_column from information_schema.table_constraints tc join information_schema.key_column_usage kcu on tc.constraint_name = kcu.constraint_name join information_schema.constraint_column_usage ccu on tc.constraint_name = ccu.constraint_name where tc.constraint_type = 'FOREIGN KEY' SQL def belongs_to @belongs_to ||= result.each_with_object(Hash.new { |h, k| h[k] = {} }) do |row, memo| memo[row['from_table']][row['from_column']] = row['to_table'] end end # rubocop:disable Naming/PredicateName def has_many @has_many ||= result.each_with_object(Hash.new { |h, k| h[k] = [] }) do |row, memo| memo[row['to_table']].push([row['from_table'], row['from_column']]) end end # rubocop:enable Naming/PredicateName private def result @result ||= TableSaw::Connection.with do |conn| conn.exec(QUERY) end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
table_saw-0.5.0 | lib/table_saw/queries/foreign_key_relationships.rb |
table_saw-0.4.0 | lib/table_saw/queries/foreign_key_relationships.rb |