Skip to content

Commit

Permalink
misc: Add support of array in map
Browse files Browse the repository at this point in the history
  • Loading branch information
vincent-pochet committed Jul 9, 2024
1 parent 4876bb0 commit dfac50e
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 1 deletion.
30 changes: 29 additions & 1 deletion lib/active_record/connection_adapters/clickhouse/oid/map.rb
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,8 @@ def deserialize(value)
def serialize(value)
return '{}' if value.nil?

"{#{value.map { |k, v| "'#{k}': '#{v}'" }.join(', ')}}"
res = value.map { |k, v| "#{quote_with_type(k, key_type)}: #{quote_with_type(v, value_type)}" }.join(', ')
"{#{res}}"
end

private
Expand All @@ -48,10 +49,37 @@ def cast_type(type)
:datetime
when /Date/
:date
when /Array\(*\)/
type
else
:string
end
end

def quote_with_type(value, type)
byebug
case type
when :string
"'#{value}'"
when :integer
value
when :datetime, :date
"'#{value.iso8601}'"
when /Array\(*\)/
"[#{value.map { |v| quote(v) }.join(', ')}]"
end
end

def quote(value)
case value
when String, Symbol
"'#{value}'"
when ::Array
"[#{value.map { |v| quote(v) }.join(', ')}]"
else
value
end
end
end
end
end
Expand Down
4 changes: 4 additions & 0 deletions lib/active_record/connection_adapters/clickhouse_adapter.rb
Original file line number Diff line number Diff line change
Expand Up @@ -112,6 +112,8 @@ def cast_type(type)
:datetime
when /Date/
:date
when /Array/
type
else
:string
end
Expand Down Expand Up @@ -267,6 +269,8 @@ def quote(value)
case value
when Array
'[' + value.map { |v| quote(v) }.join(', ') + ']'
when Hash
'{' + value.map { |k, v| "#{quote(k)}: #{quote(v)}" }.join(', ') + '}'
else
super
end
Expand Down
1 change: 1 addition & 0 deletions lib/clickhouse-activerecord/schema_dumper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -175,6 +175,7 @@ def prepare_column_options(column)
if column.type == :map
spec[:key_type] = "\"#{column.key_type}\""
spec[:value_type] = "\"#{column.value_type}\""
spec[:array] = nil
end

spec.merge(super).compact
Expand Down

0 comments on commit dfac50e

Please sign in to comment.