2023-02-11 08:21:06 -06:00
|
|
|
## Info
|
|
|
|
|
|
|
|
https://knexjs.org/guide/migrations.html#knexfile-in-other-languages
|
|
|
|
|
|
|
|
|
|
|
|
## Template
|
|
|
|
|
|
|
|
Filename: YYYYMMDDHHMMSS_name.js
|
|
|
|
|
|
|
|
```js
|
|
|
|
exports.up = function(knex) {
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
exports.down = function(knex) {
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
// exports.config = { transaction: false };
|
|
|
|
```
|
|
|
|
|
|
|
|
## Example
|
|
|
|
|
2023-06-30 04:26:37 -05:00
|
|
|
YYYY-MM-DD-HHMM-create-users-products.js
|
|
|
|
|
|
|
|
2023-06-30-1348-create-users-products.js
|
2023-02-11 08:21:06 -06:00
|
|
|
|
|
|
|
```js
|
|
|
|
exports.up = function(knex) {
|
|
|
|
return knex.schema
|
|
|
|
.createTable('users', function (table) {
|
|
|
|
table.increments('id');
|
|
|
|
table.string('first_name', 255).notNullable();
|
|
|
|
table.string('last_name', 255).notNullable();
|
|
|
|
})
|
|
|
|
.createTable('products', function (table) {
|
|
|
|
table.increments('id');
|
|
|
|
table.decimal('price').notNullable();
|
|
|
|
table.string('name', 1000).notNullable();
|
2023-06-30 13:48:42 -05:00
|
|
|
}).then(() => {
|
|
|
|
knex("products").insert([
|
|
|
|
{ price: 10, name: "Apple" },
|
|
|
|
{ price: 20, name: "Orange" },
|
|
|
|
]);
|
2023-02-11 08:21:06 -06:00
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
exports.down = function(knex) {
|
|
|
|
return knex.schema
|
|
|
|
.dropTable("products")
|
|
|
|
.dropTable("users");
|
|
|
|
};
|
|
|
|
```
|
2023-06-30 04:26:37 -05:00
|
|
|
|
|
|
|
https://knexjs.org/guide/migrations.html#transactions-in-migrations
|