Module: Ridgepole::Ext::AbstractMysqlAdapter::SchemaCreation
- Defined in:
- lib/ridgepole/ext/abstract_mysql_adapter/schema_creation.rb
Instance Method Summary collapse
Instance Method Details
#visit_PartitionDefinition(o) ⇒ Object
22 23 24 25 26 27 28 29 30 31 32 |
# File 'lib/ridgepole/ext/abstract_mysql_adapter/schema_creation.rb', line 22 def visit_PartitionDefinition(o) if o.values.key?(:in) "PARTITION #{o.name} VALUES IN (#{o.values[:in].map do |value| value.is_a?(Array) ? "(#{value.map(&:inspect).join(',')})" : value.inspect end.join(',')})" elsif o.values.key?(:to) "PARTITION #{o.name} VALUES LESS THAN (#{o.values[:to].map(&:inspect).join(',')})" else raise NotImplementedError end end |
#visit_PartitionOptions(o) ⇒ Object
9 10 11 12 13 14 15 16 17 18 19 20 |
# File 'lib/ridgepole/ext/abstract_mysql_adapter/schema_creation.rb', line 9 def visit_PartitionOptions(o) sqls = o.partition_definitions.map { |partition_definition| accept partition_definition } function = case o.type when :list "LIST COLUMNS(#{o.columns.map { |column| quote_column_name(column) }.join(',')})" when :range "RANGE COLUMNS(#{o.columns.map { |column| quote_column_name(column) }.join(',')})" else raise NotImplementedError end "ALTER TABLE #{quote_table_name(o.table)} PARTITION BY #{function} (#{sqls.join(',')})" end |