Module Sequel::Plugins::Schema::ClassMethods
In: lib/sequel/plugins/schema.rb

Methods

Public Instance methods

Creates table, using the column information from set_schema.

[Source]

    # File lib/sequel/plugins/schema.rb, line 22
22:         def create_table
23:           db.create_table(table_name, :generator=>@schema)
24:           @db_schema = get_db_schema(true)
25:           columns
26:         end

Drops the table if it exists and then runs create_table. Should probably not be used except in testing.

[Source]

    # File lib/sequel/plugins/schema.rb, line 30
30:         def create_table!
31:           drop_table rescue nil
32:           create_table
33:         end

Creates the table unless the table already exists

[Source]

    # File lib/sequel/plugins/schema.rb, line 36
36:         def create_table?
37:           create_table unless table_exists?
38:         end

Drops table.

[Source]

    # File lib/sequel/plugins/schema.rb, line 41
41:         def drop_table
42:           db.drop_table(table_name)
43:         end

Returns table schema created with set_schema for direct descendant of Model. Does not retreive schema information from the database, see db_schema if you want that.

[Source]

    # File lib/sequel/plugins/schema.rb, line 48
48:         def schema
49:           @schema || (superclass.schema unless superclass == Model)
50:         end

Defines a table schema (see Schema::Generator for more information).

This is only needed if you want to use the create_table/create_table! methods. Will also set the dataset if you provide a name, as well as setting the primary key if you defined one in the passed block.

In general, it is a better idea to use migrations for production code, as migrations allow changes to existing schema. set_schema is mostly useful for test code or simple examples.

[Source]

    # File lib/sequel/plugins/schema.rb, line 61
61:         def set_schema(name = nil, &block)
62:           set_dataset(db[name]) if name
63:           @schema = Sequel::Schema::Generator.new(db, &block)
64:           set_primary_key(@schema.primary_key_name) if @schema.primary_key_name
65:         end

Returns true if table exists, false otherwise.

[Source]

    # File lib/sequel/plugins/schema.rb, line 68
68:         def table_exists?
69:           db.table_exists?(table_name)
70:         end

[Validate]