>백엔드 개발 >C++ >엔티티 프레임 워크 코드에서 동일한 테이블의 여러 외국 키를 먼저 처리하는 방법은 무엇입니까?

엔티티 프레임 워크 코드에서 동일한 테이블의 여러 외국 키를 먼저 처리하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-29 08:18:12372검색

물리적 프레임 워크 코드가 선호됩니다. 같은 테이블에서 여러 외부 키를 처리하십시오 How to Handle Multiple Foreign Keys from the Same Table in Entity Framework Code First?
물리적 프레임 워크 코드에서 먼저 두 엔티티 사이에 설정 해야하는 관계가 발생할 수 있습니다. 이것은 초보자에게 특히 도전적입니다.

팀과 게임과 관련된 모델을 고려하는데, 각 팀에는 홈 팀과 게스트 팀이 있습니다. 그러나 기존 외부 키를 사용 하여이 모델을 생성하면 사이클 참조 오류가 발생할 수 있습니다.

문제를 이해하십시오 원래 코드 조각에 표시된 바와 같이, 외부 키가 매치 엔티티에 정의되면 실제로 매치와 팀 간의 홈타 팀과 게스트 팀 속성에 대한 한 쌍의 다중 관련성을 만듭니다. 그러나 팀은 외부 키를 통해 일치하기 때문에이 설정은 원형 참조를 유발합니다. 이주기는 데이터베이스의 제약을 위반합니다.

솔루션 : 세트 내비게이션 속성 및 ModelBuilder Fluent API 사용 이 문제를 해결하려면 내비게이션 속성 모음을 사용하는 개선 된 모델을 사용하고 물리적 프레임 워크와 함께 ModelBuilder Fluent API를 사용할 수 있습니다. 이것은 예입니다 : 팀 클래스에서 두 개의 개별 수집 내비게이션 속성을 정의합니다. 경기 클래스에서 외국 키 속성을 삭제합니다.

DBContext 클래스에서 OnModelCreating 메소드를 다시 작성하고 Fluent API 구성 관계를 사용하십시오 :

이 업데이트 된 모델에서 매치 엔티티에는 두 가지 외부 키 속성이 있지만 탐색 속성은 없습니다. 대신, 내비게이션 속성은 팀 엔티티에서 정의되며 팀에서 트래버스가 일치하도록합니다. 모델 생성 프로세스는 유창한 API를 사용하여 순환 참조를 방지하기위한 관계를 명시 적으로 지정합니다. 또한 WillCascadeOndeTe 속성은 클래스 삭제를 방지하기 위해 False로 설정되어 있으며,이 장면에서는 권장되지 않습니다.

이 방법을 따르면 물리적 프레임 워크 코드의 여러 외부 채권이 동일한 테이블을 가리키는 모델을 성공적으로 생성 할 수 있습니다.

위 내용은 엔티티 프레임 워크 코드에서 동일한 테이블의 여러 외국 키를 먼저 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.