未添加实体
采用以下基于 EF 的代码:
var newItem = context.Items.CreateObject();
newItem.ID = Guid.NewGuid();
newItem.Name = "Some text";
context.Items.AddObject(newItem);
int count = context.Items.Count();
在这种情况下什么会导致计数返回零?
Take the following EF based code:
var newItem = context.Items.CreateObject();
newItem.ID = Guid.NewGuid();
newItem.Name = "Some text";
context.Items.AddObject(newItem);
int count = context.Items.Count();
What would cause the count to return zero in this circumstance?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
你忘了它
应该看起来像这样
You forgot
It should look like this
@约翰是对的。我只是补充一下为什么?您在调用
Count
之前没有调用SaveChanges
。Count
是IQueryable
的扩展方法,它对数据库进行查询并返回存储实体的计数。您调用SaveChanges
的单元不会存储实体。如果您想要待处理插入的数量,您可以调用:
@John is right. I'm just adding why? You didn't call
SaveChanges
before callingCount
.Count
is extension method fromIQueryable
and it makes query to the database and return count of stored entities. Unit you callSaveChanges
the entity is not stored.If you want number of pending inserts you can call: