SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime
7.1.0
See the version list below for details.
dotnet add package SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime --version 7.1.0
NuGet\Install-Package SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime -Version 7.1.0
<PackageReference Include="SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime" Version="7.1.0" />
paket add SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime --version 7.1.0
#r "nuget: SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime, 7.1.0"
// Install SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime as a Cake Addin #addin nuget:?package=SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime&version=7.1.0 // Install SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime as a Cake Tool #tool nuget:?package=SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime&version=7.1.0
EFCore.SqlServer.NodaTime
Adds native support to EntityFrameworkCore for SQL Server for the NodaTime types.
When modelling, usage of the following NodaTime types are supported:
- Instant
- OffsetDateTime
- LocalDateTime
- LocalDate
- LocalTime
- Duration
When querying, standard operators are supported as well as a range of additional mappings from NodaTime properties/function to their SQL Server equivalents.
Unit Tests
All types and their methods have unit tests written to verify that the SQL is translated as expected. See individual tests for more information.
Note: To run the unit tests for the first time, you will need to uncomment the lines here. This ensures that the test DB is created locally.
Usage
To use, simply install the NuGet package:
Install-Package SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime
Note: Versioning follows the [major.minor] of EF Core so that it is easy to know which version to install. Ie, if you are using EF Core v5.x then you would install v5.x of this package. Build and revision numbers are not guaranteed to follow the same numbers.
Then call the UseNodaTime()
method as part of your SqlServer configuration during the UseSqlServer
method call:
using Microsoft.EntityFrameworkCore;
options.UseSqlServer("your DB Connection",
x => x.UseNodaTime());
Reverse Engineering (Scaffolding)
Support for reverse engineering has been added starting in v5.0.2.
The SQL Server types map as follows:
smalldatetime
→Instant
datetime
→Instant
datetime2
→Instant
date
→LocalDate
time
→LocalTime
datetimeoffset
→OffsetDateTime
Additional property / function mappings
DATEADD Support
The SQL DATEADD
function is supported for the following types:
- Instant (extension methods)
- OffsetDateTime (native and some extension methods)
- LocalDateTime (native and some extension methods)
- LocalDate (native and some extension methods)
- LocalTime (native and some extension methods)
- Duration (native and some extension methods)
Note: Please add a using statement in order to use the extension methods:
using Microsoft.EntityFrameworkCore.SqlServer.NodaTime.Extensions;
Supported Methods
- PlusYears
- PlusMonths
- PlusDays
- PlusHours
- PlusMinutes
- PlusSeconds
- PlusMilliseconds
using Microsoft.EntityFrameworkCore.SqlServer.NodaTime.Extensions;
// PlusYears
await this.Db.RaceResult
.Where(r => r.StartTime.PlusYears(1) >= Instant.FromUtc(2019, 7, 1, 1, 0))
.ToListAsync();
// Translates to:
// SELECT [r].[Id], [r].[EndTime], [r].[StartTime], [r].[StartTimeOffset]
// FROM [RaceResult] AS [r] WHERE DATEADD(year, CAST(1 AS int), [r].[StartTime]) >= '2019-07-01T01:00:00.0000000Z'
DATEPART Support
The SQL DATEPART
function is supported for the following types:
- Instant (extension methods)
- OffsetDateTime (native and some extension methods)
- LocalDateTime (native and some extension methods)
- LocalDate (native and some extension methods)
- LocalTime (native and some extension methods)
- Duration (native and some extension methods)
Note: Please add a using statement in order to use the extension methods:
using Microsoft.EntityFrameworkCore.SqlServer.NodaTime.Extensions;
Supported Parts
- Year
- Quarter
- Month
- DayOfYear
- Day
- Week
- WeekDay
- Hour
- Minute
- Second
- Millisecond
- Microsecond
- Nanosecond
- TzOffset
- IsoWeek
using Microsoft.EntityFrameworkCore.SqlServer.NodaTime.Extensions;
// Compare the 'Year' DatePart
await this.Db.RaceResult
.Where(r => r.StartTime.Year() == 2019)
.ToListAsync();
// Translates to:
// SELECT [r].[Id], [r].[EndTime], [r].[StartTime], [r].[StartTimeOffset]
// FROM [RaceResult] AS [r] WHERE DATEPART(year, [r].[StartTime]) = 2019
DATEDIFF Support
The SQL DATEDIFF
function is supported for the following types:
- Instant (extension methods)
- OffsetDateTime (extension methods)
- LocalDateTime (extension methods)
- LocalDate (extension methods)
- LocalTime (extension methods)
- Duration (extension methods)
Note: Please add a using statement in order to use the extension methods:
using Microsoft.EntityFrameworkCore.SqlServer.NodaTime.Extensions;
Supported Parts
- Year
- Quarter
- Month
- DayOfYear
- Day
- Week
- WeekDay
- Hour
- Minute
- Second
- Millisecond
- Microsecond
- Nanosecond
- TzOffset
- IsoWeek
using Microsoft.EntityFrameworkCore.SqlServer.NodaTime.Extensions;
// DateDiff based on 'day'
DbFunctions dbFunctions = null;
await this.Db.Race
.Where(r => dbFunctions.DateDiffDay(r.Date, new LocalDate(2020, 1, 1)) >= 200)
.ToListAsync();
// Translates to:
// SELECT [r].[Id], [r].[Date], [r].[ScheduledDuration], [r].[ScheduledStart], [r].[ScheduledStartTime]
// FROM [Race] AS [r]
// WHERE DATEDIFF(DAY, [r].[Date], '2020-01-01') >= 200
DATEDIFF_BIG Support
The SQL DATEDIFF_BIG
function is supported for the following types:
- Instant (extension methods)
- OffsetDateTime (extension methods)
- LocalDateTime (extension methods)
- LocalTime (extension methods)
- Duration (extension methods)
Note: Please add a using statement in order to use the extension methods:
using Microsoft.EntityFrameworkCore.SqlServer.NodaTime.Extensions;
Supported Parts
- Second
- Millisecond
- Microsecond
- Nanosecond
using Microsoft.EntityFrameworkCore.SqlServer.NodaTime.Extensions;
// DateDiffBig based on 'second'
DbFunctions dbFunctions = null;
await this.Db.RaceResult
.Where(r => dbFunctions.DateDiffBigSecond(r.StartTime, Instant.FromUtc(2019, 7, 1, 0, 0)) >= 100000)
.ToListAsync();
// Translates to:
// SELECT [r].[Id], [r].[EndTime], [r].[OffsetFromWinner], [r].[StartTime], [r].[StartTimeOffset]
// FROM [RaceResult] AS [r]
// WHERE DATEDIFF_BIG(SECOND, [r].[StartTime], '2019-07-01T00:00:00.0000000Z') >= CAST(100000 AS bigint)
Version History
- 7.1.0 (August 12, 2023)
- Added support for
LocalDateTime.Date
property - #35 - Added support for
OffsetDateTime.Date
property
- Added support for
- 7.0.0 (November 9, 2022)
- Initial release supporting EF Core 7.0.0
- 7.0.0-rc.1.22426.7 (September 25, 2022)
- Release candidate for EF Core 7
- 6.0.1
- Fixed an issue where an
ArgumentNullException
would throw if you calledUseInternalServiceProvider
- #27
- Fixed an issue where an
- 6.0.0
- Support for .Net 6 - #23
- 5.0.3
- Fixed an issue where
DateTime
queries failed in some instances - #25
- Fixed an issue where
- 5.0.2
- Added design time support - #16
- 5.0.1
- Fix SqlDateTime overflow - #13
- 5.0.0
- Support for .Net 5
- 3.1.2
- Fixed an issue where
DateTime
queries failed in some instances - #25
- Fixed an issue where
- 3.1.1
- Fix SqlDateTime overflow - #13
- 3.1.0
- Sync version number with .Net Core 3.1.0
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. 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. |
-
net6.0
- JetBrains.Annotations (>= 2022.1.0)
- Microsoft.EntityFrameworkCore.SqlServer (>= 7.0.0)
- NodaTime (>= 3.0.0)
NuGet packages (2)
Showing the top 2 NuGet packages that depend on SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime:
Package | Downloads |
---|---|
EasyDesk.CleanArchitecture.Dal.SqlServer
Utilities for the SqlServer data access layer of the clean architecture as seen by EasyDesk. |
|
SiamOutlet.IFP.Core
Core Library for IFP |
GitHub repositories (2)
Showing the top 2 popular GitHub repositories that depend on SimplerSoftware.EntityFrameworkCore.SqlServer.NodaTime:
Repository | Stars |
---|---|
ErikEJ/EFCorePowerTools
Entity Framework Core Power Tools - reverse engineering, migrations and model visualization in Visual Studio & CLI
|
|
yangzhongke/Zack.EFCore.Batch
Deleting or Updating multiple records from a LINQ Query in a SQL statement without loading entities
|
Version | Downloads | Last updated |
---|---|---|
9.0.0-rc.1.24451.1 | 827 | 9/27/2024 |
8.0.1 | 178,824 | 4/6/2024 |
8.0.0 | 120,971 | 11/18/2023 |
7.1.0 | 148,696 | 8/12/2023 |
7.0.0 | 132,362 | 11/9/2022 |
6.0.1 | 299,674 | 3/20/2022 |
6.0.0 | 173,864 | 11/8/2021 |
5.0.3 | 10,815 | 11/9/2021 |
5.0.2 | 32,696 | 4/14/2021 |
5.0.1 | 29,885 | 11/28/2020 |
5.0.0 | 846 | 11/10/2020 |
3.1.2 | 10,139 | 11/9/2021 |
3.1.1 | 14,561 | 11/28/2020 |
3.1.0 | 1,611 | 11/10/2020 |
1.3.3 | 781 | 10/20/2020 |
1.3.2 | 1,287 | 9/25/2020 |
1.3.1 | 1,459 | 9/7/2020 |
1.3.0 | 4,167 | 3/19/2020 |
1.2.0 | 815 | 3/3/2020 |