EFCore.MigrationExtensions.PostgreSQL
8.0.0
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package EFCore.MigrationExtensions.PostgreSQL --version 8.0.0
NuGet\Install-Package EFCore.MigrationExtensions.PostgreSQL -Version 8.0.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="EFCore.MigrationExtensions.PostgreSQL" Version="8.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="EFCore.MigrationExtensions.PostgreSQL" Version="8.0.0" />
<PackageReference Include="EFCore.MigrationExtensions.PostgreSQL" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add EFCore.MigrationExtensions.PostgreSQL --version 8.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: EFCore.MigrationExtensions.PostgreSQL, 8.0.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.
#addin nuget:?package=EFCore.MigrationExtensions.PostgreSQL&version=8.0.0
#tool nuget:?package=EFCore.MigrationExtensions.PostgreSQL&version=8.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
EFCore.MigrationExtensions
Adds views, synonyms, stored procedures, etc. (so-called SQL objects) to the EF model. Creates migrations, when those objects are changed. SQL objects are defined as raw SQL in C#-code or in embedded resources. They can be even generated at runtime.
All EF Core model-tracking and application features are supported:
- When SQL-objects change, migrations are generated.
- SQL-objects are applied on
Database.Migrate()
orDatabase.EnsureCreated()
. - Correct script is generated on
dotnet ef migrations script
. - Database is updated on
dotnet ef database update
.
How to use
- Call
UseSqlObjects
:- either in
builder.Services.AddDbContext
andDesignTimeDbContextFactory
- or in
DbContext.OnConfiguring
- either in
- Create an empty
DbDesignTimeServices
in your entry point. The class should inherit fromCustomNpgsqlDesignTimeServices
- Add SqlObjects to your context in
DbContext.OnModelCreating
- Generate migrations / scripts / update DB as usual
Ways to add SqlObjects to the model
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
//...
// Add SqlObject directly
// Order is used to define the order in which objects are created / updated in DB
const string Sql = "create or replace view migr_ext_tests.v_view_10 as select * from migr_ext_tests.my_table;";
modelBuilder.AddSqlObjects(new SqlObject(Name: "v_view_10", SqlCode: Sql) { Order = 10 });
// Add all embedded resources, placed in assembly's "Sql" folder
// Only *.sql resources are added
// There is no way to define order for embedded objects
// Use resources' names if you need to sort objects
modelBuilder.AddSqlObjects(assembly: typeof(Class1).Assembly, folder: "Sql");
}
Known limitations
- Doesn't drop deleted objects (generates non compilable code, so the developer should write drop-code himself).
- Only C# is supported
- PostgreSQL and SqlServer are supported, but any other DB can be easily added (use
EFCore.MigrationExtensions.PostgreSQL
as an example)
Testing
- Open TestDataAccessLayer folder in terminal
- Set connection string at TestEntryPoint/appsettings.json
- Install dotnet-ef
dotnet tool restore
- Use the following commands to add migrations / update DB
dotnet dotnet-ef migrations add MyMigr --context TestContext --project TestDataAccessLayer.csproj --startup-project ../TestEntryPoint/TestEntryPoint.csproj
dotnet dotnet-ef database update --context TestContext --project TestDataAccessLayer.csproj --startup-project ../TestEntryPoint/TestEntryPoint.csproj
dotnet dotnet-ef migrations script TestMigr Meetup1 --context TestContext --project TestDataAccessLayer.csproj --startup-project ../TestEntryPoint/TestEntryPoint.csproj
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. 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. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0
- EFCore.MigrationExtensions (>= 8.0.0)
- Npgsql.EntityFrameworkCore.PostgreSQL (>= 8.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.