>  기사  >  데이터 베이스  >  내 보기에서는 MySQL에서 단일 이름이 필요한데 Entity Framework가 복수 테이블 이름을 생성하는 이유는 무엇입니까?

내 보기에서는 MySQL에서 단일 이름이 필요한데 Entity Framework가 복수 테이블 이름을 생성하는 이유는 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-28 20:38:02766검색

Why Does Entity Framework Create Plural Table Names While My View Expects Singular Names in MySQL?

Entity Framework는 복수형 테이블 이름을 생성하지만 View에서는 단일 테이블 이름을 예상합니다.

MySQL .NET Connector 6.4.4.0 및 Entity Framework 4.1을 사용하면 개발자가 다음과 같은 문제에 직면할 수 있습니다. Entity Framework는 복수형 이름을 가진 테이블을 생성하지만 개체에 대한 뷰에서는 단일 테이블 이름을 예상합니다. 이로 인해 뷰를 표시하려고 할 때 오류가 발생할 수 있습니다.

오류 세부 정보

오류는 일반적으로 다음 예외와 함께 발생합니다.

Table 'mydb.vote' doesn't exist

이 예외는 Entity Framework가 "votes"라는 이름의 테이블을 생성했을 때 view는 "vote"라는 테이블에 액세스하려고 시도합니다(엔티티 클래스 이름이 "Vote"라고 가정).

원인

원인 이 오류는 테이블 이름 복수화에 대한 Entity Framework 규칙과 관련이 있습니다. 기본적으로 Entity Framework는 테이블 이름을 생성할 때 엔터티 클래스의 이름을 복수형으로 지정합니다. 그러나 MySQL .NET 커넥터의 Entity Framework 지원과 같은 특정 외부 요인이 이 동작에 영향을 미칠 수 있습니다.

해결책

이 문제를 해결하려면 다음과 같은 몇 가지 단계를 수행할 수 있습니다.

  1. 'DropDatabaseIfExists' 또는 'DropCreateDatabaseAlways'가 사용되는지 확인하세요. ApplicationStart 메서드는 데이터베이스 이니셜라이저를 올바르게 설정해야 합니다.
  2. 단수/복수 불일치를 제거하세요. 데이터베이스: 이는 PluralizingTableNameConvention을 제거하거나 OnModelCreating에서 ToTable("Votes")을 호출하여 달성할 수 있습니다.
  3. 애플리케이션을 실행하기 전에 데이터베이스가 있는지 확인하세요. MySQL .NET 커넥터는 데이터베이스를 자동으로 생성하지 않을 수 있으므로 데이터베이스를 수동으로 생성해야 할 수도 있습니다.

이러한 단계를 따르면 Entity Framework에서 생성한 복수형 테이블 이름과 Entity Framework에서 예상하는 단일 테이블 이름이 일치하지 않습니다. 보기를 해결할 수 있습니다.

위 내용은 내 보기에서는 MySQL에서 단일 이름이 필요한데 Entity Framework가 복수 테이블 이름을 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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