1

外部キーがオプションであるEFで関係を作成しようとしています。例: https ://stackoverflow.com/a/6023998/815553

私の質問は、上記のようなことをする方法はありますが、モデルの一部としてContactIDプロパティを保持できる場所はありますか?

私の特定のケースでは、人とバウチャーがあります。人物テーブルにはオプションのVoucherIdがあります。これは、バウチャーが人物にリンクするために後の段階でのみ着信するためです。

public class Person
{
    public int ID { get; set; }
    public string Name { get; set; }
    public string Surname { get; set; }

    public virtual Voucher Voucher { get; set; }
}

public class Voucher
{
    public int ID { get; set; }
    public string VoucherCode { get; set; }
}

modelBuilder.Entity<Person>()
    .HasOptional(p => p.Voucher)
    .WithOptionalDependent().Map(a => a.MapKey("VoucherId"));

私がここに持っているものは機能しますが、私が欲しいのは、PersonクラスにVoucherIdを持っていることです。個人にバウチャーを追加するために立っているので、バウチャーオブジェクト全体をバウチャーパラメーターに指定する必要があります。

using (DatabaseContext context = new DatabaseContext())
{
    Voucher v = new Voucher()
    {
        VoucherCode = "23423"
    };
    context.Voucher.Add(v);
    context.SaveChanges();
    Person p = new Person()
    {
        Name = "Bob",
        Surname = "Smith",
        Voucher=v
    };
    context.Person.Add(p);
    context.SaveChanges();
}

私ができるようになりたい:

Person p = new Person()
{
    Name = "Bob",
    Surname = "Smith",
    VoucherId=v.ID // I wouldn't reference it like this, I would have the ID from a different source
};
4

1 に答える 1

3

次のようにFKマッピングを作成できます。

   public class Person
   {
      public int ID { get; set; }
      public string Name { get; set; }
      public string Surname { get; set; }

      [ForeignKey( "Voucher" )]
      public int? VoucherId { get; set; }

      public virtual Voucher Voucher { get; set; }
   }
于 2012-08-24T01:04:59.807 に答える