This version of the library is no longer maintained. Please consider upgrading to the latest release

You can create new tables by using the create method. This method takes two arguments: its first argument represents the name of the table you want to create and the second argument is an anonymous callback function (Closure) that takes as an argument an instance of Opis\Database\Schema\CreateTable class.

$db->schema()->create('users', function($table){
    //add columns here
}));

The object passed as an argument to the anonymous callback function, will be further used to add columns, constraints and indexes to the newly created table.

$db->schema()->create('users', function($table){
    //add column
    $table->integer('age');
}));

Adding columns

The schema builder provides a series of methods that allows you to add columns, having different data types, to a table. The first argument that these methods take, represents the column name. Here is a list of supported column types and their associated methods:

Integer
$table->integer('age');

Adds an INTEGER equivalent column

Float
$table->float('height');

Adds a FLOAT equivalent column

Double
$table->double('distance');

Adds a DOUBLE equivalent column

Decimal
// Default precision
$table->decimal('ammount');

// Explicit precision
$table->decimal('ammount', 16, 4);

Adds a DECIMAL equivalent column, and optionally specify decimal’s precision

Boolean
$table->boolean('registered');

Adds a BOOLEAN equivalent column

Binary
$table->binary('picture');

Adds a BLOB equivalent column

String
// Default length of 255
$table->string('email');

// Explicit length
$table->string('email', 128)

Adds a VARCHAR equivalent column, and optionally specify its length

Fixed
// Default length of 255
$table->fixed('country_code');

// Explicit length
$table->fixed('country_code', 2);

Adds a CHAR equivalent column, and optionally specify its lengths

Text
$table->text('description');

Adds a TEXT equivalent column

Time
$table->time('sunrise');

Adds a TIME equivalent column

Timestamp
$table->timestamp('created_at');

Adds a TIMESTAMP equivalent column

Date
$table->date('birthday');

Adds a DATE equivalent column

DateTime
$table->dateTime('appointment');

Adds a DATETIME equivalent column

Column size

For integer, text and binary types you can specify the column size by calling the size method. The valid sizes values are: tiny, small, normal, medium and big.

$db->schema()->create('users', function($table){

    $table->integer('id')->size('big');

}));
Type Size Description
integer tiny Adds an TINYINT equivalent column to the table
integer small Adds an SMALLINT equivalent column to the table
integer normal Adds an INTEGER equivalent column to the table
integer medium Adds an MEDIUMINT equivalent column to the table
integer big Adds an BIGINT equivalent column to the table
text tiny Adds an TINYTEXT equivalent column to the table
text small Adds an TINYTEXT equivalent column to the table
text small Adds an TINYTEXT equivalent column to the table
text medium Adds an MEDIUMTEXT equivalent column to the table
text big Adds an LONGTEXT equivalent column to the table
binary tiny Adds an TINYBLOB equivalent column to the table
binary small Adds an TINYBLOB equivalent column to the table
binary normal Adds an BLOB equivalent column to the table
binary medium Adds an MEDIUMBLOB equivalent column to the table
binary big Adds an LONGBLOB equivalent column to the table

Column properties

You can specify that an integer column contains an unsigned integer value by using the unsigned method.

$table->integer('id')->unsigned();

You can provide a default value for column by using the defaultValue method.

$table->string('role', 32)->defaultValue('user');

Specifying that a column in not nullable id bone by using the notNull method.

$table->string('email')->notNull();

Column constraints

Adding a primary key constraint is done by using the primary method. The name of the constraint will be the same as the column’s name.

$table->integer('id')->primary();

Adding an unique constraint is done by using the unique method. The name of the constraint will be the same as the column’s name

$table->string('email')->unique();

For integer column types you can specify that the column’s value will be incremented automatically, when a new row is inserted into the table, by using the autoincrement method. When using this feature, a primary key constraint will be automatically added to the column.

$table->integer('id')->autoincrement();

Indexing a column

You can specify that the current column should be indexed, by calling the index method. The name of the newly added index will be the same as the column’s name.

$table->string('username', 32)->index();

Primary key

Adding a primary key for a newly created table is done using the primary method. The method takes as an argument the name of the column on which you want to add the primary key constraint. The name of the primary key will be the same as the column’s name.

$db->schema()->create('users', function($table){

    $table->integer('id');
    // ... Add other columns
    //Add primary key
    $table->primary('id');

}));

You can add only one primary key per table.

Adding a primary key that has a custom name can be done by passing as arguments to the primary method the name of the primary key and the name of the column on which the primary key will be added.

$db->schema()->create('users', function($table){

    $table->integer('id');
    // ... Add other columns
    //Add a primary key named `pk_id` on column `id`
    $table->primary('pk_id', 'id');

}));

If you want add a primary key on multiple columns, you simply have to pass as arguments to the primary method the name of the primary key and an array containing the column names on which the primary key will be added.

$db->schema()->create('users', function($table){

    $table->integer('id');
    $table->integer('group');
    // ... Add other columns
    //Add a primary key named `users_pk` on columns `id` and `group`
    $table->primary('users_pk', array('id', 'group'));

}));

Unique keys

Adding a unique key for a newly created table is done using the unique method. The method takes as an argument the name of the column on which you want to add the unique key constraint. The name of the unique key will be the same as the column’s name.

$db->schema()->create('users', function($table){

    $table->string('email');
    // ... Add other columns
    //Add unique key
    $table->unique('email');

}));

Adding a unique key that has a custom name can be done by passing as arguments to the unique method the name of the unique key and the name of the column on which the unique key will be added.

$db->schema()->create('users', function($table){

    $table->string('email');
    // ... Add other columns
    //Add a unique key named `uk_email` on column `email`
    $table->unique('uk_email', 'email');

}));

If you want add a unique key on multiple columns, you simply have to pass as arguments to the unique method the name of the unique key and an array containing the column names on which the unique key will be added.

$db->schema()->create('users', function($table){

    $table->string('email');
    $table->string('username');
    // ... Add other columns
    //Add a unique key named `uk_users` on columns `email` and `uesername`
    $table->unique('uk_users', array('email', 'username'));

}));

Foreign keys

Adding a foreign key to a newly created table is done using the foreign method. The method takes as an argument the name of the column on which you want to add the foreign key. The name of the foreign will be the same as the column’s name.

The referenced table is set by calling the references method and the referenced column is set by calling the on method.

$db->schema()->create('users', function($table){

    $table->integer('profile_id');
    // ... Add other columns
    //Add a foreign key
    $table->foreign('profile_id')->references('profiles')->on('id');

}));

You may also specify options for the on delete and on update actions by using the onDelete and onUpdate methods. These methods accepts as an argument only the following string values: cascade, restrict, no action and set null.

$db->schema()->create('users', function($table){

    $table->integer('profile_id');
    // ... Add other columns
    //Add a foreign key
    $table->foreign('profile_id')
          ->references('profiles')->on('id')
          ->onDelete('cascade')
          ->onUpdate('cascade');

}));

Adding a foreign key that has a custom name can be done by passing as arguments to the foreign method the name of the foreign key and the name of the column on which the foreign key will be added.

$db->schema()->create('users', function($table){

    $table->integer('profile_id');
    // ... Add other columns
    //Add a foreign key named `fk_custom_name` on column `profile_id`
    $table->foreign('fk_custom_name', 'profile_id')->references('profiles')->on('id');

}));

Indexes

Adding an index for a newly created table is done using the index method. The method takes as an argument the name of the column on which you want to add the index. The name of the index will be the same as the column’s name.

$db->schema()->create('users', function($table){

    $table->string('name');
    // ... Add other columns
    //Add index
    $table->index('name');

}));

Adding a index that has a custom name can be done by passing as arguments to the index method the name of the index and the name of the column that you want to be indexed.

$db->schema()->create('users', function($table){

    $table->string('name');
    // ... Add other columns
    //Add an index named `idx_name` on column `name`
    $table->index('idx_name', 'name');

}));

If you want add a index on multiple columns, you simply have to pass as arguments to the index method the name of the index and an array containing the column names on which the index will be added.

$db->schema()->create('users', function($table){

    $table->string('name');
    $table->string('email');
    // ... Add other columns
    //Add an index named `idx_users` on columns `email` and `name`
    $table->index('idx_users', array('email', 'name'));

}));