- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 Entity Framework 新手,正在尝试学习如何使用 Code First 从数据库加载实体。
我的模型包含一个用户:
public class User
{
public int UserID { get; set; }
[Required]
public string Name { get; set; }
// Navigation Properties
public virtual ICollection<AuditEntry> AuditEntries { get; set; }
}
每个用户可以有一组审核条目,每个条目包含一条简单的消息:
public class AuditEntry
{
public int AuditEntryID { get; set; }
[Required]
public string Message { get; set; }
// Navigation Properties
public int UserID { get; set; }
public virtual User User { get; set; }
}
我有一个 DBContext,它只公开两个表:
public DbSet<User> Users { get; set; }
public DbSet<AuditEntry> AuditEntries { get; set; }
我想要做的是加载包含消息的 AuditEntry 对象列表以及包含 UserID 和 Name 属性的相关 User 对象。
List<AuditEntry> auditEntries = db.AuditEntries.ToList();
因为我将导航属性标记为虚拟并且没有禁用延迟加载,所以我得到了一个无限深的对象图(每个 AuditEntry 都有一个 User 对象,其中包含 AuditEntries 列表,每个 AuditEntries 都包含一个 User对象,其中包含 AuditEntries 等列表)
如果我随后想要序列化该对象(例如作为 Web API 中的结果发送),这就不太好了。
我尝试关闭延迟加载(通过从模型中的导航属性中删除虚拟关键字,或者将 this.Configuration.LazyLoadingEnabled = false; 添加到我的 DBContext 中)。正如预期的那样,这会产生一个 AuditEntry 对象的平面列表,其中 User 设置为 null。
关闭延迟加载后,我尝试像这样急切地加载用户:
var auditentries = db.AuditEntries.Include(a => a.User);
但这会产生与以前相同的深度/循环结果。
如何加载一层深度(例如,包括用户的 ID 和名称),而不同时加载反向引用/跟随导航属性返回原始对象并创建循环?
最佳答案
经过多次黑客攻击,我在 Linq 查询中使用动态返回类型和投影提出了以下潜在的解决方案:
public dynamic GetAuditEntries()
{
var result = from a in db.AuditEntries
select new
{
a.AuditEntryID,
a.Message,
User = new
{
a.User.UserID,
a.User.Username
}
};
return result;
}
这会(在内部)生成以下看起来合理的 SQL:
SELECT
[Extent1].[AuditEntryID] AS [AuditEntryID],
[Extent1].[Message] AS [Message],
[Extent1].[UserID] AS [UserID],
[Extent2].[Username] AS [Username]
FROM [dbo].[AuditEntries] AS [Extent1]
INNER JOIN [dbo].[Users] AS [Extent2] ON [Extent1].[UserID] = [Extent2].[UserID]
这产生了我想要的结果,但似乎有点啰嗦(特别是对于比我的示例复杂得多的现实生活模型),我怀疑这会对性能产生影响。
优点
这为我返回对象的确切内容提供了很大的灵 active 。由于我通常在客户端进行大部分 UI 交互/模板,因此我经常发现自己必须创建模型对象的多个版本。我通常需要一定的粒度,让用户可以查看哪些属性(例如,我可能不想在 AJAX 请求中将每个用户的电子邮件地址发送到低权限用户的浏览器)
它允许 Entity Framework 智能地构建查询并仅选择我选择投影的字段。例如,在每个顶级 AuditEntry 对象中,我希望看到 User.UserID 和 User.Username,但不是 User.AuditEntries。
缺点
从我的 Web API 返回的类型不再是强类型,因此我无法基于此 API 创建强类型 MVC View 。碰巧这对于我的具体情况来说不是问题。
以这种方式从大型/复杂模型手动投影可能会产生大量代码,看起来工作量很大,并且有可能在 API 中引入错误。这必须仔细测试。
API 方法与模型的结构紧密耦合,并且由于这不再基于我的 POCO 类完全自动化,因此对模型所做的任何更改都必须反射(reflect)在加载它们的代码中。
包含方法?
我对 .Include() 方法的使用仍然有点困惑。据我所知,此方法将指定相关实体应与指定实体一起“急切加载”。但是,由于指导似乎是导航属性应放置在关系的两侧并标记为虚拟,因此 Include 方法似乎会导致创建一个循环,这对其有用性产生重大负面影响(尤其是在序列化时) .
就我而言,“树”看起来有点像:
AuditEntry
User
AuditEntries * n
User * n
etc
我非常有兴趣听到有关此方法的任何评论、以这种方式使用动态的影响或任何其他见解。
关于entity-framework - 如何防止Entity Framework Code First中相关实体的循环加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13453144/
目前,我正在为网络开发类(class)做作业。 这些是说明:第一行和首字下沉样式Jakob 希望文章的第一行以小写大写字母显示。转到 First Line and Drop Cap Styles 部分
.first() 方法是在 jQuery 1.4 中添加的。 :first 选择器自 1.0 以来就已存在。 来自文档: :first The :first pseudo-class is equiv
我正在审查现有的 ASP.NET MVC (5.2.3) EF (6.1.3) 项目。 该项目使用 ASP.NET Identity,我检查了 web.config 中的 2 个连接字符串,一个用于
为什么人们使用 mid=first+(last-first)/2 而不是 (first+last)/2,在二进制搜索的情况下)两者有区别吗。如果有,请告诉我,因为我无法理解其中的区别。 最佳答案 如果
为什么人们使用 mid=first+(last-first)/2 而不是 (first+last)/2,在二进制搜索的情况下)两者有区别吗。如果有,请告诉我,因为我无法理解其中的区别。 最佳答案 如果
for(auto it = M.begin(); it!=M.end();it++) { coutfirstsecondsecond == 1) return it->firs
我试图从第二个循环中获取循环的第一项。 我知道我得到了这样的@key @../key 但@first 似乎不像@../first 那样工作 有什么想法吗? 问候 最佳答案 首先,无论是否在嵌套 blo
var tab1 = $('.tabs a:first-child').attr('href'); alert(tab1); .. 尽管同一页面上有两个 div.switch,但仅匹配一个。第二个位于
我想知道如何将节点*变量 NODE 分配给结构内的数据? struct node { int info; struct node *link; }; typedef struct nod
我有两个段落包含在一个 div 中。我想让第一段的文字变大一点,但使用 :first-child 并不能像我所说的那样工作。看不出有什么问题。
我有一个 ul li 列表 Parent child1 child2
我有三个表,即员工、部门和申诉。 Employees 表有超过一百万条记录。我需要找到员工的详细信息、他/她的部门以及他/她提出的申诉。 我可以想到以下两个查询来查找结果: 1。先过滤记录,只获取需要
我有三个表,即员工、部门和申诉。 Employees 表有超过一百万条记录。我需要找到员工的详细信息、他/她的部门以及他/她提出的申诉。 我可以想到以下两个查询来查找结果: 1。先过滤记录,只获取需要
这有什么区别吗: myList.Where(item => item == 0).First(); 还有这个: myList.First(item => item == 0); 后者对我来说更有意义,
我分不清 element:first-child 之间的区别和 element:first-of-type 例如,你有一个 div div:first-child → 全部 元素是其父元素的第一个子元
当我遇到一个奇怪的情况时,我正在研究 CSS 选择器。 如果我使用 :first-child 伪元素,我需要在它前面加上一个空格才能工作,否则它将无法工作。然而 :first-letter 伪元素的情
请考虑以下字符串数组: let strings = ["str1", "str2", "str10", "str20"] 假设需要获取包含 5 个字符的第一个元素 (String),我可以使用 fil
让我们假设我们要开始新项目 - 包含一些业务逻辑的应用程序、ASP.NET 上的用户界面、WPF 或两者。我们想使用 ORM 或 DAL 代码生成器并在 .NET 类中实现我们的业务逻辑。我们可以通过
我有一种树系统。我想做的是给所有 parent 一个 margin ,除了第一个。这是我的 HTML: Test
我分不清 element:first-child 之间的区别和 element:first-of-type 例如,你有一个 div div:first-child → 全部 元素是其父元素的第一个子元
我是一名优秀的程序员,十分优秀!