EF 4.1 Code First. Table-per-type inheritance with different primary key name from its base class' primary key name

后端 未结 2 638
被撕碎了的回忆
被撕碎了的回忆 2021-01-19 05:42

Given this:

create table Location(
LocationId int identity(1,1) not null primary key,
Address nvarchar(max) not null,
City nvarchar(max) null,
State nvarchar         


        
相关标签:
2条回答
  • 2021-01-19 06:21

    As I know (and I tried it multiple times) code first doesn't support this => your derived type should use same column names for primary key.

    This problem can be described very simply: Current fluent mapping implementation doesn't allow overriding mapping rules from parent entity => parent entity defines names of primary key columns in all derived entities.

    IMO the most probable reason is that it was really designed as code first where you don't have existing database and you do not have to bother with database naming - it was up to EF to define names as it needed. Once DbContext API was released people started to use it with existing database massively. But here comes a problem: Initial use cases didn't count with this so some scenarios which are pretty easily done in EDMX are not possible. This is one of them.

    0 讨论(0)
  • 2021-01-19 06:32

    Here is a workaround for this issue:

    Create a view for the derived table and map your entity class that view. Rename the key column in your view so that it matches the key column in the base table.

    eg:

    base table User (UserID, FirstName, LastName)

    derived table Manager (ManagerID, DepartmentID)

    Entity Framework fails to update Manager as the key column is different!

    solution:

    create view UserManager
    as
    select
    ManagerID as UserID,
    DepartmentID
    from Manager
    

    Then map the Manager class to the UserManager view, instead of to the Manager table.

    0 讨论(0)
提交回复
热议问题