5-2EFCore性能优化

ASNoTracking

上文讲了实体类的跟踪以便执行SaveChanges操作。但是如果是查询操作,则实体类便不需要进行跟踪。

using TestDbContext ctx = new TestDbContext();
Book[] books = ctx.Books.AsNoTracking().Take(3).ToArray(); //设置不被跟踪
Book b1 = books[0];
b1.Title = "abc";//无效,因为不会被跟踪
EntityEntry entry1 = ctx.Entry(b1);

Find和FindAsync方法

当根据Id获取数据的时候,这两个方法会在上下文查找这个对象是否已经被跟踪,如果被跟踪,直接返回被跟踪的对象,不需要访问数据库。只有在本地没有找到这个对象时候,才去数据库查询,而Single方法则肯定要去访问数据库。

但是,在对象被跟踪之后,数据库中对应的数据被其他程序修改,如果使用Find方法则可能返回旧数据

Book b = ctx.Books.Find(2)

全局查询筛选器

设置全局查询筛选器,EF Core会自动将全局查询筛选器应用于涉及这个实体类的所有LINQ查询。常应用“软删除”功能,即并不真的删除数据,而是增加某列指示该数据是否被删除。

例如在Book类中增加一个bool属性值IsDeleted,标记是否被删除

在配置类中增加builder.HasQueryFilter(b=>b.IsDeleted==false),这样在对Book实体类的查询都会自动加上b.IsDeleted==false这个筛选器

如果需要查询被删除的数据,可以使用IgnoreQueryFilters来临时忽略过滤器

ctx.Books.IgnoreQueryFilters().Where(b=>b.Title.Contains("a"))

注意:如果启动了全局查询筛选器,会导致全表扫描,性能降低。

悲观并发控制

为了避免多个用户同时操作资源造成并发冲突问题,通常要进行并发控制。

悲观并发控制一般采用行锁、表锁等排他锁对资源进行锁定。

要使用悲观并发控制需要自行编写SQL语句。

案例:抢房子

class House
{
   
   
	public long Id {
   
    get; set</
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值