DelegateDecompiler.EntityFrameworkCore 0.32.0

dotnet add package DelegateDecompiler.EntityFrameworkCore --version 0.32.0
NuGet\Install-Package DelegateDecompiler.EntityFrameworkCore -Version 0.32.0
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="DelegateDecompiler.EntityFrameworkCore" Version="0.32.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add DelegateDecompiler.EntityFrameworkCore --version 0.32.0
#r "nuget: DelegateDecompiler.EntityFrameworkCore, 0.32.0"
#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 DelegateDecompiler.EntityFrameworkCore as a Cake Addin
#addin nuget:?package=DelegateDecompiler.EntityFrameworkCore&version=0.32.0

// Install DelegateDecompiler.EntityFrameworkCore as a Cake Tool
#tool nuget:?package=DelegateDecompiler.EntityFrameworkCore&version=0.32.0

DelegateDecompiler celebrates 10th year anniversary 🎂

https://ci.appveyor.com/project/hazzik/delegatedecompiler/branch/main https://nuget.org/packages/DelegateDecompiler

A library that is able to decompile a delegate or a method body to their lambda representation

Sponsorship

If you like the library please consider supporting my work.

Examples

Using computed properties in linq.

Asume we have a class with a computed property

class Employee
{
    [Computed]
    public string FullName => FirstName + " " + LastName;

    public string LastName { get; set; }

    public string FirstName { get; set; }
}

And you are going to query employees by their full names

var employees = (from employee in db.Employees
                 where employee.FullName == "Test User"
                 select employee).Decompile().ToList();

When you call .Decompile method it decompiles your computed properties to their underlying representation and the query will become simmilar to the following query

var employees = (from employee in db.Employees
                 where (employee.FirstName + " " + employee.LastName)  == "Test User"
                 select employee).ToList();

If your class doesn't have a [Computed] attribute, you can use the .Computed() extension method..

var employees = (from employee in db.Employees
                 where employee.FullName.Computed() == "Test User"
                 select employee).ToList();

Also, you can call methods that return a single item (Any, Count, First, Single, etc) as well as other methods in identical way like this:

bool exists = db.Employees.Decompile().Any(employee => employee.FullName == "Test User");

Again, the FullName property will be decompiled:

bool exists = db.Employees.Any(employee => (employee.FirstName + " " + employee.LastName) == "Test User");

Using with EntityFramework and other ORMs

If you are using ORM specific features, like EF's Include, AsNoTracking or NH's Fetch then Decompile method should be called after all ORM specific methods, otherwise it may not work. Ideally use Decompile extension method just before materialization methods such as ToList, ToArray, First, FirstOrDefault, Count, Any, and etc.

Async Support with EntityFramework 6

The DelegateDecompiler.EntityFramework package provides DecompileAsync extension method which adds support for EF's Async operations.

Async Support with EntityFramework Core 2.0-3.1

The DelegateDecompiler.EntityFrameworkCore package provides DecompileAsync extension method which adds support for EF's Async operations.

Async Support with EntityFramework Core 5.0 and later

The DelegateDecompiler.EntityFrameworkCore5 package provides DecompileAsync extension method which adds support for EF's Async operations.

Installation

Available on NuGet

License

MIT license - http://opensource.org/licenses/mit

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 (3)

Showing the top 3 NuGet packages that depend on DelegateDecompiler.EntityFrameworkCore:

Package Downloads
Flora.DataAccess

Package Description

LinqBuilder.EFCore.AutoMapper

Extensions for querying EF Core with AutoMapper projections.

Clywind.AspNetCore.AutoMapper

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.32.0 1,258 10/20/2022
0.31.0 375 10/17/2022
0.31.0-artifacts.30 98 10/17/2022
0.31.0-alpha.2 92 10/17/2022
0.31.0-alpha.1 96 10/17/2022
0.30.0 4,115 12/14/2021
0.29.1 15,304 2/4/2021
0.29.0 413 2/4/2021
0.28.3 1,521 1/9/2021
0.28.2 2,354 11/12/2020
0.28.1 385 11/12/2020
0.28.0 117,231 10/31/2019
0.27.0 1,832 9/30/2019
0.26.1 531 9/30/2019
0.25.0 28,184 1/2/2019
0.24.0 46,686 4/28/2018