You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
uptime-kuma/db/knex_migrations
Nelson Chan 67250d6302
Feat: Retries persistence (#3814)
1 year ago
..
2023-08-16-0000-create-uptime.js Uptime calculation improvement and 1-year uptime (#2750) 1 year ago
2023-08-18-0301-heartbeat.js Uptime calculation improvement and 1-year uptime (#2750) 1 year ago
2023-09-29-0000-heartbeat-retires.js Feat: Retries persistence (#3814) 1 year ago
2023-10-11-1915-push-token-to-32.js push monitor: increase token security (#912) 1 year ago
README.md Fix few markdownlint warnings (#3825) 1 year ago

README.md

Info

https://knexjs.org/guide/migrations.html#knexfile-in-other-languages

Basic rules

  • All tables must have a primary key named id
  • Filename format: YYYY-MM-DD-HHMM-patch-name.js
  • Avoid native SQL syntax, use knex methods, because Uptime Kuma supports SQLite and MariaDB.

Template

exports.up = function(knex) {

};

exports.down = function(knex) {

};

// exports.config = { transaction: false };

Example

Filename: 2023-06-30-1348-create-user-and-product.js

exports.up = function(knex) {
  return knex.schema
    .createTable('user', function (table) {
        table.increments('id');
        table.string('first_name', 255).notNullable();
        table.string('last_name', 255).notNullable();
    })
    .createTable('product', function (table) {
        table.increments('id');
        table.decimal('price').notNullable();
        table.string('name', 1000).notNullable();
    }).then(() => {
        knex("products").insert([
            { price: 10, name: "Apple" },
            { price: 20, name: "Orange" },
        ]);
    });
};

exports.down = function(knex) {
  return knex.schema
      .dropTable("product")
      .dropTable("user");
};

https://knexjs.org/guide/migrations.html#transactions-in-migrations