Database for organizational directory-services, Region Örebro län. That is, for the moment, EF Core entities and db-contexts. There are two concrete db-contexts:
- SqliteOrganizationContext
- SqlServerOrganizationContext
Migrations exist for:
- SqliteOrganizationContext
- SqlServerOrganizationContext
You can create your own migrations for other database-providers.
Drop the "StrongName.snk" file in the repository-root. The file should not be included in source control.
We might want to create/recreate/update migrations. If we can accept data-loss we can recreate the migrations otherwhise we will have to update them. For each update we need to bump the migration-name suffix:
- Initial migration: "Function"
- First update: "Function1"
- Second update: "Function2"
Copy all the commands below and run them in the Package Manager Console.
If you want more migration-information you can add the -Verbose parameter:
Add-Migration Function -Context FunctionContext -OutputDir Some/Path/To/Your/Migrations -Project Project -StartupProject Project -Verbose;
Write-Host "Removing migrations...";
Remove-Migration -Context SqliteOrganizationContext -Force -Project Project -StartupProject Project;
Remove-Migration -Context SqlServerOrganizationContext -Force -Project Project -StartupProject Project;
Write-Host "Removing current migrations-directory...";
Remove-Item "Project\Migrations" -ErrorAction Ignore -Force -Recurse;
Write-Host "Creating migrations...";
Add-Migration Organization -Context SqliteOrganizationContext -OutputDir Migrations/Sqlite -Project Project -StartupProject Project;
Add-Migration Organization -Context SqlServerOrganizationContext -OutputDir Migrations/SqlServer -Project Project -StartupProject Project;
Write-Host "Finnished";
Copy all the commands below and run them in the Package Manager Console.
Write-Host "Updating migrations...";
Add-Migration Organization1 -Context SqliteOrganizationContext -OutputDir Migrations/Sqlite -Project Project -StartupProject Project;
Add-Migration Organization1 -Context SqlServerOrganizationContext -OutputDir Migrations/SqlServer -Project Project -StartupProject Project;
Write-Host "Finnished";
If we want to know how we should code our DbContexts / Entities we can use Scaffold-DbContext. Create a database first with eg. Microsoft SQL Server Management Studio through the designer or with scripts. Then scaffold a db-context from it. Then we can look at the generated classes and see how we should "code first".
- Create a LocalDB-database named eg. "07390b07-29ed-4944-aced-df2ad5b4dbc2".
- Create your database tables etc.
- Run: Scaffold-DbContext "Data Source=(LocalDB)\MSSQLLocalDB;Initial Catalog=07390b07-29ed-4944-aced-df2ad5b4dbc2" Microsoft.EntityFrameworkCore.SqlServer -ContextDir "" -OutputDir "Your-directory"
- Delete the database
CREATE TABLE [Entries] (
[Id] INT IDENTITY (1, 1) NOT NULL,
[Created] DATETIME DEFAULT(GETDATE()) NOT NULL,
[Disabled] BIT DEFAULT(1) NOT NULL,
[DistinguishedName] NVARCHAR (400) NOT NULL,
[Guid] UNIQUEIDENTIFIER DEFAULT(NEWID()) NOT NULL,
[Identity] NVARCHAR (50) NOT NULL,
[Saved] DATETIME DEFAULT(GETDATE()) NOT NULL,
CONSTRAINT [PK_Entries] PRIMARY KEY CLUSTERED ([Id] ASC)
);
GO
CREATE UNIQUE NONCLUSTERED INDEX [IX_Entries_DistinguishedName]
ON [Entries]([DistinguishedName] ASC);
GO
CREATE UNIQUE NONCLUSTERED INDEX [IX_Entries_Guid]
ON [Entries]([Guid] ASC);
GO
CREATE UNIQUE NONCLUSTERED INDEX [IX_Entries_Identity]
ON [dbo].[Entries]([Identity] ASC);
GO
CREATE TABLE [Organizations]
(
[Id] INT NOT NULL,
[TelephoneNumber] NVARCHAR(20),
CONSTRAINT [PK_Organizations] PRIMARY KEY CLUSTERED ([Id] ASC),
CONSTRAINT [FK_Organizations_Entries] FOREIGN KEY ([Id]) REFERENCES [Entries] ([Id])
ON DELETE CASCADE
ON UPDATE NO ACTION
);
GO
CREATE TRIGGER [AfterOrganizationDelete] ON [Organizations]
AFTER DELETE
AS
BEGIN
DELETE
FROM [Entries]
WHERE [Id] IN (SELECT [Id] FROM DELETED);
END;