• 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中找到对象,所以无法删除。

  • 相关阅读:
    [算法] Tarjan算法求割点
    [题解] POJ2689 [质数距离]
    [题解] 「NOIP2009」最优贸易
    pyCharm更换主题、字体大小和编辑器字体颜色
    python之冒泡排序简单算法
    修改pip阿里镜像
    Postman工具简介
    接口文档解析
    HTTP接口请求
    接口(API)测试学习
  • 原文地址:https://www.cnblogs.com/nonkicat/p/3586966.html
Copyright © 2020-2023  润新知