DelegateDecompiler.EntityFrameworkCore
0.33.1
DelegateDecompiler.EntityFrameworkCore5
Additional DetailsThis package provides support for Entity Framework Core 2.0-3.1. These versions of EF Core are no longer supported. Please consider upgrading to EF Core 5 or above. To do so, please uninstall DelegateDecompiler.EntityFrameworkCore and install DelegateDecompiler.EntityFrameworkCore5.
dotnet add package DelegateDecompiler.EntityFrameworkCore --version 0.33.1
NuGet\Install-Package DelegateDecompiler.EntityFrameworkCore -Version 0.33.1
<PackageReference Include="DelegateDecompiler.EntityFrameworkCore" Version="0.33.1" />
paket add DelegateDecompiler.EntityFrameworkCore --version 0.33.1
#r "nuget: DelegateDecompiler.EntityFrameworkCore, 0.33.1"
// Install DelegateDecompiler.EntityFrameworkCore as a Cake Addin #addin nuget:?package=DelegateDecompiler.EntityFrameworkCore&version=0.33.1 // Install DelegateDecompiler.EntityFrameworkCore as a Cake Tool #tool nuget:?package=DelegateDecompiler.EntityFrameworkCore&version=0.33.1
DelegateDecompiler celebrates 10th year anniversary 🎂
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
- Install-Package DelegateDecompiler
- Install-Package DelegateDecompiler.EntityFramework
- Install-Package DelegateDecompiler.EntityFrameworkCore
- Install-Package DelegateDecompiler.EntityFrameworkCore5
License
MIT license - http://opensource.org/licenses/mit
Product | Versions 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. |
-
.NETStandard 2.0
- DelegateDecompiler (>= 0.33.1)
- Microsoft.EntityFrameworkCore (>= 2.0.0 && < 4.0.0)
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.33.1 | 220 | 5/3/2024 | |
0.33.0 | 81 | 5/3/2024 | |
0.32.0 | 1,591 | 10/20/2022 | |
0.31.0 | 415 | 10/17/2022 | |
0.30.0 | 4,890 | 12/14/2021 | |
0.29.1 | 16,107 | 2/4/2021 | |
0.29.0 | 452 | 2/4/2021 | |
0.28.3 | 1,818 | 1/9/2021 | |
0.28.2 | 2,398 | 11/12/2020 | |
0.28.1 | 424 | 11/12/2020 | |
0.28.0 | 118,979 | 10/31/2019 | |
0.27.0 | 1,873 | 9/30/2019 | |
0.26.1 | 566 | 9/30/2019 | |
0.25.0 | 30,895 | 1/2/2019 | |
0.24.0 | 49,669 | 4/28/2018 |