When creating a column from the Blueprint object, a Column object is returned. This column gives you access to a few modifier commands to further configure the column.
comment
Attach a comment to the column.
Argument
Type
Required
Default
Description
comment
string
true
The comment text.
Example:
SchemaBuilder
schema.create( "users",function( table ) {table.integer( "age" ).comment( "Do not lie about your age" );} );
SQL (MySQL)
CREATE TABLE `users` (`age` INTEGER NOT NULL COMMENT `Do not lie about your age`)
default
Sets a default value for the column.
Note: The value is not escaped, allowing you to specify functions like NOW() or literals like 1. To specify a literal string, wrap the value in quotes.
CREATE TABLE "posts" ("posted_date"TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP)
storedAs
Creates a stored computed column. Computed columns are defined as expressions between other columns and/or constant values. Stored computed columns are saved in the database to avoid computing on every query.
Your database grammar may not differentiate between stored computed columns and virtual computed columns. Research your grammar's implementation for more details.
CREATE TABLE `products` (`price` INTEGER NOT NULL,`tax` INTEGER GENERATED ALWAYS AS (price *0.0675) STORED NOT NULL)
CREATE TABLE [products] ( [price] INTEGER NOT NULL, [tax] AS (price *0.0675) PERSISTED)
CREATE TABLE "products" ("price" INTEGER NOT NULL,"tax" INTEGER NOT NULL GENERATED ALWAYS AS (price *0.0675) STORED)
CREATE TABLE "PRODUCTS" ("PRICE" NUMBER(10, 0) NOT NULL,"TAX" NUMBER(10, 0) GENERATED ALWAYS AS (price *0.0675))
virtualAs
Creates a virtual computed column. Computed columns are defined as expressions between other columns and/or constant values. Virtual computed columns are computed on every query.
Your database grammar may not differentiate between stored computed columns and virtual computed columns. Research your grammar's implementation for more details.