私は2つのモデルを持っています:
public class Exchanger : BaseContract
{
[DataMember, Key, Column(TypeName = "bigint")]
public long Id { get; set; }
....
[DataMember]
public virtual ICollection<PaymentSystem> PaymentSystems { get; set; }
}
[DataContract, Serializable]
public class PaymentSystem : BaseContract
{
[Key, Column(TypeName = "bigint"), DataMember]
public long Id { get; set; }
...
[DataMember, JsonIgnore]
public virtual ICollection<Exchanger> ExchangersSupport { get; set; }
}
多対多の関係を持つ流暢なAPIの指示:
modelBuilder.Entity<Exchanger>()
.HasMany(t => t.PaymentSystems)
.WithMany(t => t.ExchangersSupport)
.Map(m => m.ToTable("ExchangerToPaymentSystem"));
挿入するコード:
public void Create(Exchanger ex, long clientId)
{
if (_context != null)
{
ex.ClientId = clientId;
ex.LastTimeUpdated = DateTime.UtcNow;
_context.Exchangers.Add(ex);
_context.SaveChanges();
}
}
Exchanger テーブル EF に新しいエントリを挿入すると、ExchangerToPaymentSystem テーブルにエントリが作成され、PaymentSystem テーブルにも同じエントリが同時に作成されます。私が更新しているとき、何も起こりません。私は何を間違っていますか?