EF7 - HasOne関係のカスタム列名

entity-framework entity-framework-core

質問

EF7でHasOne関係でカスタム列名をどのように指定しますか?

次のサンプルクラスを考えてみましょう。

public class House
{
    public int Id { get; set; }
    public int BedroomCount { get; set; }
    public Address Address { get; set; }
}

public class Address
{
    public int Id { get; set; }
    public string StreetName { get; set; }
    public string StreetNumber { get; set; }
}

そして、この流暢な構成:

modelBuilder.Entity<House>()
    .HasOne(x => x.Address)
    .WithOne()
    .OnDelete(DeleteBehavior.Cascade);

これはこのDB設定につながります:

CREATE TABLE [House] (
[Id] int NOT NULL IDENTITY,
[AddressId] int,
[BedroomCount] int NOT NULL,
CONSTRAINT [PK_House] PRIMARY KEY ([Id]),
CONSTRAINT [FK_House_Address_AddressId] FOREIGN KEY ([AddressId]) REFERENCES [Address] ([Id]) ON DELETE CASCADE);

CREATE TABLE [Address] (
[Id] int NOT NULL IDENTITY,
[StreetName] nvarchar(max),
[StreetNumber] nvarchar(max),
CONSTRAINT [PK_Address] PRIMARY KEY ([Id]));

ハウステーブルに "AddressId"以外の列名を指定するにはどうすればよいですか?私は非ナビゲーションのプロパティのようなHasColumnNameに似たメソッドを見つけることができません。

私はEntity Framework 7 RC1-Finalを使用しています。

人気のある回答

Data Annotationsを使用して、関係の外部キーを構成することができます。

public int AddressID { get; set; }

[ForeignKey("AddressID")]
public Address Address { get; set; }

これには、関係で外部キーとして使用されるプロパティが必要です。また、シャドー外部キー以外の関係については明示的な外部キーを持つことをお勧めします。これにより、 Houseプロパティを保存するためにナビゲーションプロパティのAddress全体を設定する必要がないため、挿入/更新時に多くの問題が発生することはありません。 ここの問題を見る

テストされていないかもしれませんが、おそらくこれが動作する可能性があります(今EF7をインストールする方法が見つかりません)

modelBuilder.Entity<House>()
    .HasOne(x => x.Address)
    .WithOne()
    .OnDelete(DeleteBehavior.Cascade);
    .HasForeignKey(x => x.AddressID);

他の例はここで確認できます: 外部キーの関係EF7



Related

ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ
ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ