Is it normal for NPoco/PetaPoco Fetch() to get all data and then filter client side?

淺唱寂寞╮ 提交于 2019-12-23 17:30:05

问题


I've noticed a huge difference in how NPoco (or PetaPoco) works depending on which function you call when you are using LINQ.

For instance compare Fetch() which Query() which both appear to do the same thing:

A: Fetch<EntryImage>().Where(t => t.EntryType == type && t.EntryID == entryID);

B: Query<EntryImage>().Where(t => t.EntryType == type && t.EntryID == entryID);

A returns every row in the table (10,000+) and then filters client side.

B returns just the one row I'm expecting.

I find this behavior is quite dangerous - it would be very easy to write very badly performing code without really evening noticing. Is this expected behavior? If this is normal behavior, is there any way to get a list of methods which work this way, so I can avoid using them where possible?


回答1:


This is expected behavior for NPoco.

As per source:

Fetch returns a list.

    /// <summary>
    /// Fetch all objects of type T from the database using the conventions or configuration on the type T. 
    /// Caution: This will retrieve ALL objects in the table
    /// </summary>
    List<T> Fetch<T>();

Query returns IQueryProviderWithIncludes (similar to IQueryable)

    /// <summary>
    /// Entry point for LINQ queries
    /// </summary>
    IQueryProviderWithIncludes<T> Query<T>();



回答2:


If you are using PetaPoco (*), neither of the initial code samples are great - but the issue is not Fetch vs Query.

In both instances, the SQL being submitted to the server is basically "SELECT * FROM EntryImage" (run a sql trace and confirm that if you aren't sure).

Fetch vs Query doesn't alter the SQL being sent to the server - it just alters how that data is served up client side (i.e. as a List or a deferred execution IEnumerable via yield).

To do what you want, check out PetaPoco's documentation :

var sql=PetaPoco.Sql.Builder()
            .Select("*")
            .From("articles")
            .Where("date_created < @0", DateTime.UtcNow) // fluent Where clause
            .OrderBy("date_created DESC");

(*) If you are using NPoco, see above for the answer.



来源:https://stackoverflow.com/questions/38128988/is-it-normal-for-npoco-petapoco-fetch-to-get-all-data-and-then-filter-client-s

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!