本文主要是介绍Flask后端之建立模型类间的外键联系,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1、模型类代码:
定义了三个模型类:User
、Goods
和 Sign:
class User(db.Model):__tablename__ = 'user'id = db.Column(db.Integer, primary_key=True)name = db.Column(db.String(100), nullable=False)email = db.Column(db.String(100), unique=True, nullable=False)# 建立与 Sign 模型的一对多关系signs = db.relationship('Sign', back_populates='user')
class Goods(db.Model):__tablename__ = 'goods'id = db.Column(db.Integer, primary_key=True)name = db.Column(db.String(100), nullable=False)price = db.Column(db.Float, nullable=False)# 建立与 Sign 模型的一对多关系signs = db.relationship('Sign', back_populates='goods')
class Sign(db.Model):__tablename__ = 'sign'id = db.Column(db.Integer, primary_key=True)user_id = db.Column(db.Integer, db.ForeignKey('user.id'), nullable=False)goods_id = db.Column(db.Integer, db.ForeignKey('goods.id'), nullable=False)# 建立与 User 模型的多对一关系user = db.relationship('User', back_populates='signs')# 建立与 Goods 模型的多对一关系goods = db.relationship('Goods', back_populates='signs')
2、解释:
Sign
模型类使用了 ForeignKey
来定义了与 User
和 Goods
模型的外键关系,并通过 relationship
方法建立了模型之间的关联关系。back_populates
参数用于在 Sign
模型中指定与 User
和 Goods
模型的关联属性名,这样就可以在应用中方便地访问相关联的对象。
这篇关于Flask后端之建立模型类间的外键联系的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!