SQLAlchemy 外鍵約束驗證
在 SQLAlchemy 中,外鍵約束確保引用列值存在於引用的表中。這對於維護資料完整性至關重要。但是,有時我們需要更複雜的驗證,例如確保引用的列值也引用回引用行。
考慮以下範例:
choice_id 是否引用對對應變數(variable_id) 有效的option 。
使用子查詢進行驗證
為了實現這一點,我們可以在外鍵約束中使用子查詢:import sqlalchemy as sa class SystemVariable(sa.Model): __tablename__ = "systemvariables" variable_id = sa.Column(sa.Integer, primary_key=True) variable = sa.Column(sa.String) choice_id = sa.Column( sa.Integer, sa.ForeignKey("variableoptions.option_id"), sa.CheckConstraint( "variable_id IN (SELECT variable_id FROM variableoptions WHERE option_id = choice_id)" ) ) class VariableOption(sa.Model): __tablename__ = "variableoptions" option_id = sa.Column(sa.Integer, primary_key=True) option = sa.Column(sa.String) variable_id = sa.Column(sa.Integer, sa.ForeignKey("systemvariables.variable_id"))
SystemVariables 中的choice_id值存在於 VariableOptions 表以及對應的 variable_id 中VariableOptions 與 SystemVariables 中的 中的 。 帶有附加列的擴展外鍵
或者,我們可以擴展外鍵以包含兩者option_id 和
variable_id:此方法消除了對子查詢的需要,並確保與先前的方法相同的驗證。
兩者方法提供了在 SQLAlchemy 中實現複雜外鍵約束的有效方法。方法的選擇取決於應用程式的特定要求。class SystemVariable(sa.Model): __tablename__ = "systemvariables" variable_id = sa.Column(sa.Integer, primary_key=True) variable = sa.Column(sa.String) choice_id = sa.Column( sa.Integer, sa.ForeignKey("variableoptions.option_id") ) variable_id_option = sa.Column( sa.Integer, sa.ForeignKey("variableoptions.variable_id") )
以上是如何在SQLAlchemy中實作複雜的外鍵約束?的詳細內容。更多資訊請關注PHP中文網其他相關文章!