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

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

Patricia Arquette
풀어 주다: 2025-01-29 07:59:38
원래의
112명이 탐색했습니다.

물리적 프레임 워크 코드가 선호됩니다. 같은 테이블에서 두 개의 외부 키를 처리하십시오 물리적 프레임 워크 코드를 사용하여 엔티티 간의 관계를 우선시 할 때 동일한 테이블에서 설정 해야하는 두 개의 외부 키가 발생할 수 있습니다. 이것은 초보자에게 특히 도전적입니다.

팀과 게임에 대한 데이터 모델을 만들고 싶다고 가정합니다. 선호하는 코드를 사용하면 다음 코드를 작성할 수 있습니다.

그러나이 코드는 이상을 유발합니다 <strong> 이 참조 관계는 원치 않는 사이클 참조로 이어질 것입니다. [제약 이름 = match_guestteam] </strong> <sol>이 문제를 해결하려면 EF가 외부 키를 매핑하는 다른 방법을 제공해야합니다. 효과적인 솔루션은 </sol>

클래스에서 홈 게임과 어웨이 게임을위한 별도의 컬렉션을 만드는 것입니다.

클래스에서는

속성을 ​​제거하고 외부 키 속성을 정의 할 수 있습니다.

마지막으로, 클래스에서 및

구성 관계를 사용해야합니다 :
<code class="language-csharp">public class Team
{
    [Key]
    public int TeamId { get; set; }
    public string Name { get; set; }

    public virtual ICollection<Match> Matches { get; set; }
}

public class Match
{
    [Key]
    public int MatchId { get; set; }

    [ForeignKey("HomeTeam"), Column(Order = 0)]
    public int HomeTeamId { get; set; }
    [ForeignKey("GuestTeam"), Column(Order = 1)]
    public int GuestTeamId { get; set; }

    public float HomePoints { get; set; }
    public float GuestPoints { get; set; }
    public DateTime Date { get; set; }

    public virtual Team HomeTeam { get; set; }
    public virtual Team GuestTeam { get; set; }
}</code>
로그인 후 복사
이러한 변경을 통해 물리적 프레임 워크 코드 우선 순위 모델에서 동일한 테이블에서 두 개의 외부 키를 성공적으로 설정할 수 있습니다.

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿