Gridify.EntityFramework 2.0.0-beta.2

This is a prerelease version of Gridify.EntityFramework.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Gridify.EntityFramework --version 2.0.0-beta.2                
NuGet\Install-Package Gridify.EntityFramework -Version 2.0.0-beta.2                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Gridify.EntityFramework" Version="2.0.0-beta.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Gridify.EntityFramework --version 2.0.0-beta.2                
#r "nuget: Gridify.EntityFramework, 2.0.0-beta.2"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Gridify.EntityFramework as a Cake Addin
#addin nuget:?package=Gridify.EntityFramework&version=2.0.0-beta.2&prerelease

// Install Gridify.EntityFramework as a Cake Tool
#tool nuget:?package=Gridify.EntityFramework&version=2.0.0-beta.2&prerelease                

Gridify

Nuget Nuget Nuget (with prereleases) GitHub branch checks state

Easy and optimized way to apply Filtering, Sorting and pagination using text-based data.

The best use case of this library is Asp-net APIs. When you need to get some string base filtering conditions to filter data or sort it by a field name or apply pagination concepts to your lists and return a pageable, data grid ready information, from any repository or database.

Performance comparison

Filtering is the most expensive feature in gridify. the following benchmark is comparing filtering in the most known dynamic linq libraries. As you can see, gridify has the closest result to the native linq. Also, i Should note other features like Pagination and Sorting have almost zero overhead in Gridify.

BenchmarkDotNet=v0.13.0, OS=Windows 10.0.19043.1165 (21H1/May2021Update) 11th Gen Intel Core i5-11400F 2.60GHz, 1 CPU, 12 logical and 6 physical cores .NET SDK=5.0.301 [Host] : .NET 5.0.7 (5.0.721.25508), X64 RyuJIT DefaultJob : .NET 5.0.7 (5.0.721.25508), X64 RyuJIT

Method Mean Error StdDev Ratio RatioSD Gen 0 Gen 1 Allocated
Native Linq 737.0 us 4.95 us 4.39 us 1.00 0.00 5.8594 2.9297 36 KB
Gridify 774.5 us 13.60 us 12.72 us 1.05 0.02 6.8359 2.9297 46 KB
DynamicLinq 902.7 us 16.33 us 15.28 us 1.22 0.02 19.5313 9.7656 122 KB
Sieve 982.3 us 11.06 us 10.35 us 1.33 0.01 8.7891 3.9063 54 KB
Fop 2,954.8 us 14.16 us 12.55 us 4.01 0.03 50.7813 23.4375 311 KB

WebApi Simple Usage example

// ApiController

[Produces(typeof(Paging<Person>))]
public IActionResult GetPersons([FromQuery] GridifyQuery gQuery)
{
    // Gridify => Filter,Sort & Apply Paging 
    // in short, Gridify returns data especially for data Grids. 
    return myDbContext.Persons.Gridify(gQuery);
}

complete request sample:

http://exampleDomain.com/api/GetPersons?pageSize=100&page=1&orderBy=FirstName&filter=Age%3D%3D10

Also, we can totally ignore GridifyQuery

http://exampleDomain.com/api/GetPersons

What is GridifyQuery (basic usage example)

GridifyQuery is a simple class for configuring Filtering,Paging,Sorting.

// usually, we don't need to create this object manually
// for example, we get this object as a parameter from our API Controller
var gQuery = new GridifyQuery()
{
    Filter = "FirstName=John",
    Page = 1,
    PageSize = 20,
    OrderBy = "LastName"
};

Paging<Person> pData =
         myDbContext.Persons  // we can use Any list or repository or EntityFramework context
          .Gridify(gQuery); // Filter,Sort & Apply Paging


// pData.Count => Count persons with 'John', First name
// pData.Data      => First 20 Persons with 'John', First Name

ApplyFiltering

Also, if you don't need paging and sorting features simply use ApplyFiltering extension instead of Gridify.

var query = myDbContext.Persons.ApplyFiltering("name = John");
// this is equal to : 
// myDbContext.Persons.Where(p => p.Name == "John");

see more examples in the tests

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (5)

Showing the top 5 NuGet packages that depend on Gridify.EntityFramework:

Package Downloads
EasyExtensions.EntityFrameworkCore

Ready-to-use library for simplifying the development of .NET applications.

Pandatech.GridifyExtensions

Pandatech.Gridify.Extensions simplifies and extends the functionality of the Gridify NuGet package. It provides additional extension methods and functionality to streamline data filtering and pagination, making it more intuitive and powerful to use in .NET applications. Our enhancements ensure more flexibility, reduce boilerplate code, and improve overall developer productivity when working with Gridify.

KFKLib.Gridify.AutoMapper

Package Description

DataExplorer.EfCore.Unstable

Library featuring common patterns (Unit of Work, Repository, Specification, Services) in regard to working with EF Core.

BBConsultoria.Antares.OpenSdk.Data.EntityFramework

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.15.1 1,633 11/14/2024
2.15.0 3,756 10/31/2024
2.15.0-preview7 2,621 8/28/2024
2.15.0-preview5 150 8/14/2024
2.15.0-preview4 545 7/18/2024
2.15.0-preview3 372 6/29/2024
2.15.0-preview2 230 6/22/2024
2.15.0-preview1 86 6/21/2024
2.14.2 54,438 6/8/2024
2.14.1 89,301 12/4/2023
2.14.0 8,823 11/18/2023
2.13.1 1,761 11/12/2023
2.13.0 190 11/11/2023
2.12.0 1,687 10/27/2023
2.11.1 16,693 10/6/2023
2.11.0 147 10/5/2023
2.10.1 4,020 9/28/2023
2.10.0 1,715 9/20/2023
2.10.0-preview1 117 9/19/2023
2.9.2 848 9/15/2023
2.9.1 7,432 8/22/2023
2.9.0 1,785 8/18/2023
2.8.4 46,826 4/18/2023
2.8.3 12,638 3/4/2023
2.8.2 45,230 12/7/2022
2.8.1 135,858 10/7/2022
2.8.0 8,552 7/22/2022
2.7.5 38,171 6/6/2022
2.7.4 8,017 4/22/2022
2.7.3 772 4/13/2022
2.7.2 772 4/12/2022
2.7.1 3,129 3/2/2022
2.7.0 485 3/1/2022
2.6.0 14,234 1/14/2022
2.5.0 4,756 12/27/2021
2.4.8 3,399 12/15/2021
2.4.7 299 12/14/2021
2.4.6 309 12/10/2021
2.4.5 476 12/5/2021
2.4.5-alpha5 198 12/5/2021
2.4.5-alpha4 211 12/5/2021
2.4.5-alpha1 167 12/2/2021
2.4.4 17,950 11/20/2021
2.4.3 711 11/19/2021
2.4.2 756 11/19/2021
2.4.1 1,902 11/18/2021
2.4.0 553 11/18/2021
2.3.3 456 11/16/2021
2.3.2 857 11/1/2021
2.3.1 1,185 10/19/2021
2.3.0 3,860 10/4/2021
2.2.1 345 9/30/2021
2.2.0 368 9/28/2021
2.1.0 438 9/21/2021
2.0.0 357 9/18/2021
2.0.0-beta.3 158 9/17/2021
2.0.0-beta.2 154 9/16/2021
2.0.0-beta.1 192 9/15/2021
2.0.0-alpha.1 175 8/12/2021
1.4.2 8,349 8/8/2021
1.4.1 462 8/4/2021
1.4.0 373 8/4/2021
1.3.5 1,011 7/28/2021
1.3.4 1,872 7/16/2021
1.3.3 466 7/1/2021
1.3.2 371 6/30/2021
1.3.1 361 6/23/2021
1.1.2 417 4/16/2021
1.1.1 347 4/16/2021
1.1.0 1,370 9/17/2020
1.0.5 536 7/3/2020
1.0.4 470 7/3/2020
1.0.3 549 7/2/2020
1.0.2 458 7/2/2020
1.0.1 432 7/2/2020
1.0.0 673 7/1/2020