Sha256: 75a2fd18fee5676fad69718b957150d1874fca7ba741ded7e6e339ca45264813
Contents?: true
Size: 1.76 KB
Versions: 5
Compression:
Stored size: 1.76 KB
Contents
module SQL class TableModifier extend DataMapper::Property::Lookup attr_accessor :table_name, :opts, :statements, :adapter def initialize(adapter, table_name, opts = {}, &block) @adapter = adapter @table_name = table_name.to_s @opts = (opts) @statements = [] self.instance_eval &block end def add_column(name, type, opts = {}) column = SQL::TableCreator::Column.new(@adapter, name, type, opts) @statements << "ALTER TABLE #{quoted_table_name} ADD COLUMN #{column.to_sql}" end def drop_column(name) # raise NotImplemented for SQLite3. Can't ALTER TABLE, need to copy table. # We'd have to inspect it, and we can't, since we aren't executing any queries yet. # TODO instead of building the SQL queries when executing the block, create AddColumn, # AlterColumn and DropColumn objects that get #to_sql'd if name.is_a?(Array) name.each{ |n| drop_column(n) } else @statements << "ALTER TABLE #{quoted_table_name} DROP COLUMN #{quote_column_name(name)}" end end alias_method :drop_columns, :drop_column def rename_column(name, new_name, opts = {}) # raise NotImplemented for SQLite3 @statements << "ALTER TABLE #{quoted_table_name} RENAME COLUMN #{quote_column_name(name)} TO #{quote_column_name(new_name)}" end def change_column(name, type, opts = {}) column = SQL::TableCreator::Column.new(@adapter, name, type, opts) @statements << @adapter.change_column_type_statement(table_name, column) end def quote_column_name(name) @adapter.send(:quote_name, name.to_s) end def quoted_table_name @adapter.send(:quote_name, table_name) end def to_sql @statements.join(';') end end end
Version data entries
5 entries across 5 versions & 2 rubygems