跳至主要內容
版本:v6 - 穩定版

使用舊有資料表

雖然開箱即用的 Sequelize 看起來有點主觀,但透過定義(否則會自動產生)的資料表和欄位名稱,您可以輕鬆使用舊有資料表並讓您的應用程式具有前瞻性。

資料表

class User extends Model {}
User.init(
{
// ...
},
{
modelName: 'user',
tableName: 'users',
sequelize,
},
);

欄位

class MyModel extends Model {}
MyModel.init(
{
userId: {
type: DataTypes.INTEGER,
field: 'user_id',
},
},
{ sequelize },
);

主鍵

Sequelize 預設會假設您的資料表具有 id 主鍵屬性。

若要定義您自己的主鍵

class Collection extends Model {}
Collection.init(
{
uid: {
type: DataTypes.INTEGER,
primaryKey: true,
autoIncrement: true, // Automatically gets converted to SERIAL for postgres
},
},
{ sequelize },
);

class Collection extends Model {}
Collection.init(
{
uuid: {
type: DataTypes.UUID,
primaryKey: true,
},
},
{ sequelize },
);

如果您的模型完全沒有主鍵,您可以使用 Model.removeAttribute('id');

即使沒有主鍵,仍然可以使用 Model.findOneModel.findAll 擷取實例。
雖然目前可以使用它們的實例方法 (instance.saveinstance.update 等),但這樣做會導致難以察覺的錯誤,並計劃在未來的重大更新中移除。

資訊

如果您的模型沒有主鍵,您需要使用以下實例方法的靜態等效方法,並提供您自己的 where 參數

  • instance.save: Model.update
  • instance.update: Model.update
  • instance.reload: Model.findOne
  • instance.destroy: Model.destroy
  • instance.restore: Model.restore
  • instance.decrement: Model.decrement
  • instance.increment: Model.increment

外鍵

// 1:1
Organization.belongsTo(User, { foreignKey: 'owner_id' });
User.hasOne(Organization, { foreignKey: 'owner_id' });

// 1:M
Project.hasMany(Task, { foreignKey: 'tasks_pk' });
Task.belongsTo(Project, { foreignKey: 'tasks_pk' });

// N:M
User.belongsToMany(Role, {
through: 'user_has_roles',
foreignKey: 'user_role_user_id',
});
Role.belongsToMany(User, {
through: 'user_has_roles',
foreignKey: 'roles_identifier',
});