forge->addField([ 'id' => [ 'type' => 'INT', 'constraint' => 11, 'unsigned' => true, 'auto_increment' => true, ], 'title' => [ 'type' => 'VARCHAR', 'constraint' => 255, ], 'slug' => [ 'type' => 'VARCHAR', 'constraint' => 255, ], 'content' => [ 'type' => 'LONGTEXT', ], 'status' => [ 'type' => 'ENUM', 'constraint' => ['draft', 'published'], 'default' => 'draft', ], 'published_at' => [ 'type' => 'DATETIME', 'null' => true, ], 'created_by' => [ 'type' => 'INT', 'constraint' => 11, 'unsigned' => true, ], 'created_at' => [ 'type' => 'DATETIME', 'null' => true, ], 'updated_at' => [ 'type' => 'DATETIME', 'null' => true, ], ]); $this->forge->addKey('id', true); $this->forge->addUniqueKey('slug'); $this->forge->addKey('created_by'); $this->forge->addKey('status'); $this->forge->addForeignKey('created_by', 'users', 'id', 'CASCADE', 'CASCADE'); $this->forge->createTable('news', true, ['ENGINE' => 'InnoDB']); } public function down() { $this->forge->dropTable('news'); } }