diff --git a/lib/active_record/connection_adapters/clickhouse_adapter.rb b/lib/active_record/connection_adapters/clickhouse_adapter.rb index fb73993..d59f646 100644 --- a/lib/active_record/connection_adapters/clickhouse_adapter.rb +++ b/lib/active_record/connection_adapters/clickhouse_adapter.rb @@ -300,9 +300,11 @@ def create_schema_dumper(options) # :nodoc: end # @param [String] table + # @option [Boolean] single_line # @return [String] - def show_create_table(table) - do_system_execute("SHOW CREATE TABLE `#{table}`")['data'].try(:first).try(:first).gsub(/[\n\s]+/m, ' ').gsub("#{@config[:database]}.", "") + def show_create_table(table, single_line: true) + sql = do_system_execute("SHOW CREATE TABLE `#{table}`")['data'].try(:first).try(:first) + single_line ? sql.squish : sql end # Create a new ClickHouse database. diff --git a/lib/clickhouse-activerecord/tasks.rb b/lib/clickhouse-activerecord/tasks.rb index 7440a17..a4a8a85 100644 --- a/lib/clickhouse-activerecord/tasks.rb +++ b/lib/clickhouse-activerecord/tasks.rb @@ -40,7 +40,7 @@ def structure_dump(*args) # get all tables tables = connection.execute("SHOW TABLES FROM #{@configuration.database} WHERE name NOT LIKE '.inner_id.%'")['data'].flatten.map do |table| next if %w[schema_migrations ar_internal_metadata].include?(table) - connection.show_create_table(table).gsub("#{@configuration.database}.", '') + connection.show_create_table(table, single_line: false).gsub("#{@configuration.database}.", '') end.compact # sort view to last