使用 Sequelize.js 和 Postgres 在 Code First 中处理数据
Handling Data in Code First With Sequelize.js and Postgres
我创建了一个新的 Postgres 数据库,并开始用数据填充 tables。
table 之间的关系不同。
我正在使用 node.js 应用程序和 sequelize 来处理代码首次迁移。
我的问题是我不太确定应该如何以代码优先的方式处理数据本身。
每个迁移脚本都包含如下简单内容:
up - 创建一个 table,
down - 删除 table(以及其中的所有数据)
我想知道的是我应该如何处理超时添加到不同 table 的所有数据?
目前,如果我决定在任何脚本上 运行 'db:migrate:undo',它将删除 table 和其中的所有数据。
我也希望在数据恢复方面得到全面支持,所以如果我需要做 'db:migrate:undo:all',一旦我再次 运行 'db:migrate'将恢复所有以前的数据。
是否有实现该目标的好方法?或者这是一种不好的做法?
编辑:
当前的示例文件-
module.exports = {
up: (queryInterface, Sequelize) =>
queryInterface.createTable('LookupType', {
id: {
allowNull: false,
primaryKey: true,
type: Sequelize.UUID,
},
name: {
type: Sequelize.STRING(32),
allowNull: false,
},
createdAt: {
allowNull: false,
type: Sequelize.DATE,
},
updatedAt: {
allowNull: false,
type: Sequelize.DATE,
},
},
{
schema: 'lov'
}),
down: (queryInterface /* , Sequelize */) =>
queryInterface.dropTable(
{
tableName: 'LookupType',
schema: 'lov'
}),
};
迁移实际上只是关于管理和版本控制 schema,尤其是在开发和部署阶段。
在开发中,您可能拥有测试数据,您可以将其植入数据库并在迁移回滚期间愉快地丢弃,但这在生产系统上可能是灾难性的。
我的观点是,一旦您 运行 在生产环境中进行了迁移,除非绝对必要,否则您将无法回头,在这种情况下,您将需要另一个过程来备份和恢复您的数据。
我创建了一个新的 Postgres 数据库,并开始用数据填充 tables。 table 之间的关系不同。 我正在使用 node.js 应用程序和 sequelize 来处理代码首次迁移。
我的问题是我不太确定应该如何以代码优先的方式处理数据本身。
每个迁移脚本都包含如下简单内容:
up - 创建一个 table, down - 删除 table(以及其中的所有数据)
我想知道的是我应该如何处理超时添加到不同 table 的所有数据?
目前,如果我决定在任何脚本上 运行 'db:migrate:undo',它将删除 table 和其中的所有数据。
我也希望在数据恢复方面得到全面支持,所以如果我需要做 'db:migrate:undo:all',一旦我再次 运行 'db:migrate'将恢复所有以前的数据。
是否有实现该目标的好方法?或者这是一种不好的做法?
编辑: 当前的示例文件-
module.exports = {
up: (queryInterface, Sequelize) =>
queryInterface.createTable('LookupType', {
id: {
allowNull: false,
primaryKey: true,
type: Sequelize.UUID,
},
name: {
type: Sequelize.STRING(32),
allowNull: false,
},
createdAt: {
allowNull: false,
type: Sequelize.DATE,
},
updatedAt: {
allowNull: false,
type: Sequelize.DATE,
},
},
{
schema: 'lov'
}),
down: (queryInterface /* , Sequelize */) =>
queryInterface.dropTable(
{
tableName: 'LookupType',
schema: 'lov'
}),
};
迁移实际上只是关于管理和版本控制 schema,尤其是在开发和部署阶段。
在开发中,您可能拥有测试数据,您可以将其植入数据库并在迁移回滚期间愉快地丢弃,但这在生产系统上可能是灾难性的。
我的观点是,一旦您 运行 在生产环境中进行了迁移,除非绝对必要,否则您将无法回头,在这种情况下,您将需要另一个过程来备份和恢复您的数据。