0

我在两个元素 Sfera 和 Contenuti 之间有 NN 关系。

在 Sfera 项目上,我看到 Contenuti 实体集,在 Contenuti 中,我看到 Sfera 集。

当我通过代码添加新项目时,我使用如下结构:

using (IndexDB DB = new IndexDB())
        {
            try
            {
                var newContenuto = new Contenuto();
                newContenuto.Cancellato = false;
                newContenuto.PK_Content_ID = tt_content_id;
                newContenuto.URL = URL;
                foreach(long sphere in SphereID)
                {
                    try
                    {
                        var sfere = from sfera in DB.Sfera where sfera.PK_Sfera == sphere select sfera;
                        newContenuto.Sfera.Add(sfere.First());
                        sfere.First().Contenuto.Add(newContenuto);
                    }
                    catch (Exception exc)
                    {
                        return new StandardResponse() {Success = false, Message = exc.Message};
                    }
                }
                DB.AddToContenuto(newContenuto);
                DB.SaveChanges();
                return new StandardResponse() {Success = true};
            }
            catch (Exception e)
            {
                return new StandardResponse() { Success = false, Message = e.Message + e.StackTrace };
            }

如果我看一下我的数据库,它会很好地存储我在右侧“NN”表中的两个元素之间的关系......但是当我尝试访问元素 Contenuto.Sfera 和 Sfera.Contenuto 总是空集.. .

要访问我做这样的事情:

using (IndexDB DB = new IndexDB())
        {
            var sfere = from sfera in DB.Sfera where sfera.PK_Sfera == IDSfera && sfera.Attiva select sfera;

            if (!sfere.Any())
            {
                response.Add(new UrlResponse() { Success = false, ErrorMessage = "" });
            }
            var sferaSelezionata = sfere.First();
//HERE sferaSelezionata.Contenuto.Count == 0 even if on DB there are MANY "connections"
}

}

我该如何处理?

非常感谢!

4

1 回答 1

1

尝试Include()在您的查询中使用。

var sfere = from sfera in DB.Sfera.Include("Contenuto") where sfera.PK_Sfera == IDSfera && sfera.Attiva select sfera; 
于 2012-04-12T15:22:58.610 回答