zoukankan      html  css  js  c++  java
  • C# Entity Framework查询小技巧 NoTracking

    在使用Entity Framework做查询的时候,如果只需要显示,而不用保存实体,那么可以用AsNoTracking()来获取数据。

    这样可以提高查询的性能。

    代码如下:

    var context = new Entities(connectStr);
    var contentlist = context.Set<Content>().AsQueryable().AsNoTracking();
      
    

    但是如果取到数据后,要对数据做修改并保存,则无法反映到数据库里。

    如:

    var context = new Entities(connectStr);
    var contentlist = context.Set<Content>().AsQueryable().AsNoTracking();
    
    var content = contentlist.Where(o => o.Id == 18).FirstOrDefault();
    content.Id = 19;
    context.SaveChanges();

    虽然修改后对数据库进行了Commit,再次读取后发现这条数据的Id还是18。

    另外如果对通过AsNoTracking得到的数据做删除处理,则会报错。

    如:

    var context = new Entities(connectStr);
    var contentlist = context.Set<Content>().AsQueryable().AsNoTracking();
    
    var content = contentlist.Where(o => o.Id == 18).FirstOrDefault();
    context.Set<Content>().Remove(content);
    context.SaveChanges();
    

    执行后会抛出System.InvalidOperationException异常,

    原因是:オブジェクトは ObjectStateManager 内に見つからなかったため削除できません。

    中文意思是:因为无法在ObjectStateManager中找到对象,所以无法删除。

  • 相关阅读:
    Go 场景
    sourcetree clone 提示url无效
    简单去重比较/复杂数据去重处理
    vue组件之间的通信
    js-执行机制之同步、异步、宏任务、微任务
    react生命周期
    git push被忽略的文件 处理
    请求头的属性
    运算精度问题https://blog.csdn.net/smile_ping/article/details/80284969
    react中状态提升
  • 原文地址:https://www.cnblogs.com/nonkicat/p/3586966.html
Copyright © 2011-2022 走看看