SQLAlchemy教程(六)relationship中lazy的

如果你使用了relationship建立了关系,那么lazy起到了非常重要的作用,因为这会涉及到一些查询性能的问题

接下先创建两个表分别是select(选择表),option(选项表),两个表的关系是一对多(一个选择下面包括多个选项)

class Select(db.Model):
    __tablename__ = "select"
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    title = db.Column(db.String(32), unique=True, nullable=False)
    options = db.relationship("Option", back_populates="selects", cascade="all",lazy="select")


class Option(db.Model):
    __tablename__ = "option"
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    title = db.Column(db.String(32), unique=True, nullable=False)
    select_id = db.Column(db.String(32), db.ForeignKey("select.id"))
    selects = db.relationship("Select", back_populates="options")

接下来添加数据

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值