繁体   English   中英

EntityFramework ToListAsync()不起作用

[英]EntityFramework ToListAsync() does not work

我尝试调用EF方法ToListAsync。 但没有任何事情发生 - 没有例外,没有超时只是运行。

这是我的代码。

        private IQueryable<Place> placeCompleteQuery;
    protected IQueryable<Place> PlaceCompleteQuery
    {
        get
        {
            return this.placeCompleteQuery ?? (this.placeCompleteQuery = this.Context.Places.Include(p => p.Address).
                Include(p => p.CreatedBy).
                Include(p => p.Source).
                Include(p => p.Type.Translations).
                Include(p => p.Ratings));
        }
    }

    public async Task<IList<Place>> GetPlacesByLocationAsync(DbGeography location, int radius)
    {
        List<Place> temporaryResult = PlaceCompleteQuery.Where(p => p.Location.Distance(location) <= radius).
            ToList();

        return await PlaceCompleteQuery.Where(p => p.Location.Distance(location) <= radius).
            ToListAsync();
    }

ToList方法的第一次同步调用立即返回结果。 ToListAsync的第二次异步调用仍在运行,没有结果也没有异常。

有什么建议?

我怀疑你的调用堆栈更进一步,你的代码调用Task.WaitTask<T>.Result 如果你在UI线程或ASP.NET请求上下文中执行此操作, 您的代码将会死锁 ,正如我在我的博客上解释的那样。

要修复它,请使用await而不是Task.WaitTask<T>.Result

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM