• EF Core性能优化(一)


    跟踪查询
      返回实体类型的查询是默认会被跟踪的。 这表示可以更改这些实体实例,然后通过 SaveChanges() 持久化这些更改。
    非跟踪查询
      在只读方案中使用结果时,非跟踪查询十分有用。 可以更快速地执行非跟踪查询,因为无需设置更改跟踪信息。 如果不需要更新从数据库中检索到的实体,则应使用非跟踪查询。 可以将单个查询替换为非跟踪查询。

    具体详情可查看微软官方跟踪与非跟踪查询

    实体状态由EntityState枚举定义:Detached(未跟踪)、Unchanged(未改变)、Added(已添加)、Deleted(已删除)、Modified(已修改)

    using System.Threading.Tasks;
    using Core.Web.Models;
    using Microsoft.AspNetCore.Mvc;
    using Microsoft.EntityFrameworkCore;
    
    namespace Core.Web.Controllers
    {
        public class RegionController : Controller
        {
            private readonly DataContext _dataContext;
            public RegionController(DataContext dataContext)
            {
                _dataContext = dataContext;
            }
            //非跟踪查询
            public async Task<IActionResult> Index()
            {
                var regions = await _dataContext.Region.AsNoTracking().ToListAsync();
                return View(regions);
            }
            //非跟踪增加
            public async Task<bool> Add(Region region)
            {
                region.RegionID = 11;
                region.RegionDescription = "青岛";
                _dataContext.Entry(region).State = EntityState.Added;
                int res = await _dataContext.SaveChangesAsync();
                return res > 0;
            }
            //非跟踪修改
            public async Task<bool> Edit(Region region)
            {
                region.RegionID = 11;
                region.RegionDescription = "菏泽";
                _dataContext.Entry(region).State = EntityState.Modified;
                int res = await _dataContext.SaveChangesAsync();
                return res > 0;
            }
            //非跟踪删除
            public async Task<bool> Del(Region region)
            {
                region.RegionID = 11;
                _dataContext.Entry(region).State = EntityState.Deleted;
                int res = await _dataContext.SaveChangesAsync();
                return res > 0;
            }
        }
    }
  • 相关阅读:
    1.Apache与Tomcat
    jeeplus 多选框
    GIT 回滚
    jsp 中data 转换 字符串
    Pattern和Matcher中表达式
    web.xml 详细介绍
    $.ajax()方法详解
    My 2016
    如何做好一个保安队长。
    集合之WeakHashMap
  • 原文地址:https://www.cnblogs.com/liessay/p/12936244.html
Copyright © 2020-2023  润新知