using System; using Microsoft.EntityFrameworkCore.Migrations; using NodaTime; using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata; #nullable disable namespace FictionArchive.Service.UserNovelDataService.Migrations { /// public partial class AddBookmarks : Migration { /// protected override void Up(MigrationBuilder migrationBuilder) { migrationBuilder.CreateTable( name: "Users", columns: table => new { Id = table.Column(type: "uuid", nullable: false), OAuthProviderId = table.Column(type: "text", nullable: false), CreatedTime = table.Column(type: "timestamp with time zone", nullable: false), LastUpdatedTime = table.Column(type: "timestamp with time zone", nullable: false) }, constraints: table => { table.PrimaryKey("PK_Users", x => x.Id); }); migrationBuilder.CreateTable( name: "Bookmarks", columns: table => new { Id = table.Column(type: "integer", nullable: false) .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), UserId = table.Column(type: "uuid", nullable: false), ChapterId = table.Column(type: "bigint", nullable: false), NovelId = table.Column(type: "bigint", nullable: false), Description = table.Column(type: "text", nullable: true), CreatedTime = table.Column(type: "timestamp with time zone", nullable: false), LastUpdatedTime = table.Column(type: "timestamp with time zone", nullable: false) }, constraints: table => { table.PrimaryKey("PK_Bookmarks", x => x.Id); table.ForeignKey( name: "FK_Bookmarks_Users_UserId", column: x => x.UserId, principalTable: "Users", principalColumn: "Id", onDelete: ReferentialAction.Cascade); }); migrationBuilder.CreateIndex( name: "IX_Bookmarks_UserId_ChapterId", table: "Bookmarks", columns: new[] { "UserId", "ChapterId" }, unique: true); migrationBuilder.CreateIndex( name: "IX_Bookmarks_UserId_NovelId", table: "Bookmarks", columns: new[] { "UserId", "NovelId" }); } /// protected override void Down(MigrationBuilder migrationBuilder) { migrationBuilder.DropTable( name: "Bookmarks"); migrationBuilder.DropTable( name: "Users"); } } }