📅  最后修改于: 2023-12-03 15:08:48.141000             🧑  作者: Mango
在 Sequelize 中,引用是表示模型之间关系的一种方法,例如外键。在 TypeScript 中,您可以使用类型配置选项来设置引用。下面是如何在 Sequelize 类型配置选项中设置引用的步骤:
在 Sequelize 中,有三种类型的关系:一对一、一对多和多对多。您需要定义每个模型之间的关系以传达它们之间的关系。假设我们有两个模型:User 和 Post,我们可以通过以下方式定义它们之间的关系:
// User 模型
class User extends Model<User> {}
User.init({
name: DataTypes.STRING,
}, { sequelize });
// Post 模型
class Post extends Model<Post> {}
Post.init({
title: DataTypes.STRING,
content: DataTypes.STRING,
}, { sequelize });
// 定义关系
User.hasMany(Post, { as: "posts", foreignKey: "userId" });
Post.belongsTo(User, { as: "user", foreignKey: "userId" });
在上面的代码示例中,我们为 User 模型和 Post 模型定义了一对多的关系。User 模型通过 hasMany() 方法关联到 Post 模型,Post 模型通过 belongsTo() 方法关联到 User 模型。 hasMany() 方法允许我们定义一个 Post 数组作为 User 的属性,而 belongsTo() 方法允许我们将 User 模型中的属性作为 Post 的属性。
类型配置选项允许我们在模型定义中设置引用。对于上面的示例,我们可以将 User 模型中的 posts 属性设置为 Post 模型的引用:
// User 模型
interface UserAttributes {
name: string;
}
interface UserInstance extends Model<UserAttributes>, UserAttributes {}
const User = sequelize.define<UserInstance>("User", {
name: DataTypes.STRING,
}, {
timestamps: false,
});
// Post 模型
interface PostAttributes {
title: string;
content: string;
userId: number;
}
interface PostInstance extends Model<PostAttributes>, PostAttributes {}
const Post = sequelize.define<PostInstance>("Post", {
title: DataTypes.STRING,
content: DataTypes.STRING,
userId: {
type: DataTypes.INTEGER,
references: {
model: User,
key: "id",
},
},
}, {
timestamps: false,
});
// 定义关系
User.hasMany(Post, { as: "posts", foreignKey: "userId" });
Post.belongsTo(User, { as: "user", foreignKey: "userId" });
在上面的代码示例中,我们通过 references 属性将 User 模型设置为 Post 模型的引用。 references 属性使用一个对象,该对象中包含一个 model 属性和一个 key 属性。 model 属性表示要引用的模型,key 属性表示要引用的属性。在这种情况下,我们将 User 模型设置为引用,并将其 id 属性用作引用属性。
这是关于如何在 Sequelize 类型配置选项中设置引用的简单介绍!