DD.WellWorkover.Cloud/AsbCloudDb
2021-12-27 10:53:18 +05:00
..
Migrations Fix DB Models. Specify TypeName = "timestamp with time zone" on DateTime. 2021-12-27 10:53:18 +05:00
Model Fix DB Models. Specify TypeName = "timestamp with time zone" on DateTime. 2021-12-27 10:53:18 +05:00
UsefulQueries BIG. Add timescaleDB into DB. 2021-11-13 18:47:11 +05:00
AsbCloudDb.csproj update EF 2021-09-23 15:26:55 +05:00
EFExtentions.cs add telemetry merge 2021-12-17 12:48:58 +05:00
install pg timescale.md BIG. Add timescaleDB into DB. 2021-11-13 18:47:11 +05:00
Readme.md Add/refactor services for permissions authorization model. 2021-12-11 16:46:04 +05:00

Миграции

EF tools

https://docs.microsoft.com/ru-ru/ef/core/cli/dotnet

Установка:

dotnet tool install --global dotnet-ef

Обновление:

dotnet tool update --global dotnet-ef

Создать миграцию

dotnet ef migrations add <MigrationName> --project AsbCloudDb

Откатить миграцию

dotnet ef migrations remvoe <MigrationName> --project AsbCloudDb

<MigrationName> - Name of migration class. После создания миграции обязательно прочитать сгенерированый код.

Применить миграции

При старте проекта применяются автоматически

 dotnet ef database update --project .\AsbCloudDb

Backup and restore

Backup

Terminal:

sudo -u postgres pg_dump -Fc -U postgres postgres -W > dump_2021-11-26.bak

Restore backup

Step 1. (Re)Create DB and schema IF needed.

psql:

--drop schema public cascade;
CREATE DATABASE postgres;
\c postgres
create schema public;

Step 2. Innit timescaledb and prepare DB to restore

CREATE EXTENSION IF NOT EXISTS timescaledb;
SELECT timescaledb_pre_restore();

Step 3. Restore DB, then [Longest operation]

Terminal:

sudo -u postgres  psql -p 5499 -U postgres postgres -W < dump_2021-11-26.bak

OR psql:

\! pg_restore -Fc -d postgres dump_2021-11-26.bak

Then 'exit resore mode' psql:

SELECT timescaledb_post_restore();