SQLAlchemy 외래 키 제약 조건 유효성 검사
SQLAlchemy에서 외래 키 제약 조건은 참조 열 값이 참조된 테이블에 존재하는지 확인합니다. 이는 데이터 무결성을 유지하는 데 필수적입니다. 그러나 참조된 열 값이 참조 행을 다시 참조하는지 확인하는 등 더 복잡한 유효성 검사가 필요한 경우도 있습니다.
다음 예를 고려하세요.
이런 경우에는 choice_id가 해당 변수(variable_id)에 유효한 옵션을 참조하는지 확인하는 데이터베이스 제약조건을 추가하세요.
검증을 위해 하위 쿼리 사용
이를 달성하기 위해 우리는 외래 키 제약 조건 내에서 하위 쿼리를 사용할 수 있습니다.
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의 variable_id와 일치합니다.
추가 열이 있는 확장 외래 키
또는 , 외래 키를 확장하여 두 가지를 모두 포함할 수 있습니다.option_id 및 variable_id:
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!