SQL Server 2012 データベースに対して DbContext POCO アプローチを使用して、Entity Framework 4.3.1 を使用しています。
データベースには 2 つのテーブルしかなく、次のようになります。
注: データベースには外部キーがまったく指定されていません。モデルで関係を強制しているだけです (データベースを変更することはできません)。
それぞれに、次のような 1 行のデータがあります。
結合が機能することを確認するために、次のクエリを実行しました。
現在、次のエンティティがあります。
public class Two
{
public long TwoId { get; set; }
public string OneId { get; set; }
public virtual One One { get; set; }
}
public class One
{
public string OneId { get; set; }
public DateTime DeliveryDate { get; set; }
public virtual ICollection<Two> Twos { get; private set; }
public void AddTwo(Two two)
{
if (two == null)
throw new ArgumentNullException("two");
if (Twos == null)
Twos = new List<Two>();
if (!Twos.Contains(two))
Twos.Add(two);
two.One = this;
}
}
そして、これはコンテキストです:
public class TestContext : DbContext
{
public TestContext(string conectionString)
: base(conectionString)
{
Configuration.LazyLoadingEnabled = true;
Ones = Set<One>();
Twos = Set<Two>();
}
public DbSet<One> Ones { get; private set; }
public DbSet<Two> Twos { get; private set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
var one = modelBuilder.Entity<One>();
one.ToTable("One");
one.HasKey(d => d.OneId);
var two = modelBuilder.Entity<Two>();
two.ToTable("Two");
two.HasKey(d => new
{
d.OneId,
d.TwoId
});
two.Property(p => p.TwoId)
.HasDatabaseGeneratedOption(DatabaseGeneratedOption.None);
two.HasRequired(t => t.One)
.WithMany(o => o.Twos)
.HasForeignKey(o => o.OneId);
base.OnModelCreating(modelBuilder);
}
}
このコードを実行するWhy is this printed?
と、コンソールに出力されます。ナビゲーション プロパティを入力する必要があることがわかります (明示的に含めていることもあります)。
using (var ctx = new TestContext(@"......"))
{
const string oneId = "111348718";
var one = ctx.Ones.Single(o => o.OneId.Equals(oneId));
if (one != null)
{
var sdi = ctx
.Twos
.Include(s => s.One)
.Single(s => s.OneId.Equals(oneId));
if (sdi.One == null)
{
Console.WriteLine("Why is this printed?");
}
else
{
Console.WriteLine("This is what I expect");
}
}
}
さて、これは本当に奇妙なビットです。クラスDeliveryDate
からプロパティをコメントアウトするだけで、正常に機能します(コンソールに出力されます)。One
This is what I expect
ここで何が問題で、どうすれば解決できますか?
注:変数のDeliveryDate
プロパティを見るone
と、期待値に正しく設定されているため、日付はデータベースで問題なく、エンティティ フレームワークはそれを完全に具現化できます。
詳細情報: 日付であるという事実は問題ではありません - もしそうであれば、nvarchar はまだ失敗します - 単純なプロパティがすべてを失敗させるようです - これは私にはバグのように感じます...