From 5808bd6efb42847560ed10b2cc56323594d241de Mon Sep 17 00:00:00 2001 From: 杨宇千 Date: Mon, 19 Aug 2019 01:46:48 +0800 Subject: Migrate database. --- .../20190818174505_AddUserAvatar.Designer.cs | 83 ++++++++++++++++++++++ .../Migrations/20190818174505_AddUserAvatar.cs | 62 ++++++++++++++++ .../Migrations/DatabaseContextModelSnapshot.cs | 31 ++++++++ 3 files changed, 176 insertions(+) create mode 100644 Timeline/Migrations/20190818174505_AddUserAvatar.Designer.cs create mode 100644 Timeline/Migrations/20190818174505_AddUserAvatar.cs (limited to 'Timeline') diff --git a/Timeline/Migrations/20190818174505_AddUserAvatar.Designer.cs b/Timeline/Migrations/20190818174505_AddUserAvatar.Designer.cs new file mode 100644 index 00000000..b0a105d0 --- /dev/null +++ b/Timeline/Migrations/20190818174505_AddUserAvatar.Designer.cs @@ -0,0 +1,83 @@ +// +using System; +using Microsoft.EntityFrameworkCore; +using Microsoft.EntityFrameworkCore.Infrastructure; +using Microsoft.EntityFrameworkCore.Migrations; +using Microsoft.EntityFrameworkCore.Storage.ValueConversion; +using Timeline.Entities; + +namespace Timeline.Migrations +{ + [DbContext(typeof(DatabaseContext))] + [Migration("20190818174505_AddUserAvatar")] + partial class AddUserAvatar + { + protected override void BuildTargetModel(ModelBuilder modelBuilder) + { +#pragma warning disable 612, 618 + modelBuilder + .HasAnnotation("ProductVersion", "2.2.6-servicing-10079") + .HasAnnotation("Relational:MaxIdentifierLength", 64); + + modelBuilder.Entity("Timeline.Entities.User", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnName("id"); + + b.Property("AvatarId"); + + b.Property("EncryptedPassword") + .IsRequired() + .HasColumnName("password"); + + b.Property("Name") + .IsRequired() + .HasColumnName("name") + .HasMaxLength(26); + + b.Property("RoleString") + .IsRequired() + .HasColumnName("roles"); + + b.Property("Version") + .ValueGeneratedOnAdd() + .HasColumnName("version") + .HasDefaultValue(0L); + + b.HasKey("Id"); + + b.HasIndex("AvatarId"); + + b.ToTable("users"); + }); + + modelBuilder.Entity("Timeline.Entities.UserAvatar", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnName("id"); + + b.Property("Data") + .IsRequired() + .HasColumnName("data"); + + b.Property("Type") + .IsRequired() + .HasColumnName("type"); + + b.HasKey("Id"); + + b.ToTable("user_avatars"); + }); + + modelBuilder.Entity("Timeline.Entities.User", b => + { + b.HasOne("Timeline.Entities.UserAvatar", "Avatar") + .WithMany() + .HasForeignKey("AvatarId"); + }); +#pragma warning restore 612, 618 + } + } +} diff --git a/Timeline/Migrations/20190818174505_AddUserAvatar.cs b/Timeline/Migrations/20190818174505_AddUserAvatar.cs new file mode 100644 index 00000000..7e0843c4 --- /dev/null +++ b/Timeline/Migrations/20190818174505_AddUserAvatar.cs @@ -0,0 +1,62 @@ +using System; +using Microsoft.EntityFrameworkCore.Metadata; +using Microsoft.EntityFrameworkCore.Migrations; + +namespace Timeline.Migrations +{ + public partial class AddUserAvatar : Migration + { + protected override void Up(MigrationBuilder migrationBuilder) + { + migrationBuilder.AddColumn( + name: "AvatarId", + table: "users", + nullable: true); + + migrationBuilder.CreateTable( + name: "user_avatars", + columns: table => new + { + id = table.Column(nullable: false) + .Annotation("MySql:ValueGenerationStrategy", MySqlValueGenerationStrategy.IdentityColumn), + data = table.Column(nullable: false), + type = table.Column(nullable: false) + }, + constraints: table => + { + table.PrimaryKey("PK_user_avatars", x => x.id); + }); + + migrationBuilder.CreateIndex( + name: "IX_users_AvatarId", + table: "users", + column: "AvatarId"); + + migrationBuilder.AddForeignKey( + name: "FK_users_user_avatars_AvatarId", + table: "users", + column: "AvatarId", + principalTable: "user_avatars", + principalColumn: "id", + onDelete: ReferentialAction.Restrict); + } + + protected override void Down(MigrationBuilder migrationBuilder) + { + migrationBuilder.DropForeignKey( + name: "FK_users_user_avatars_AvatarId", + table: "users"); + + migrationBuilder.DropTable( + name: "user_avatars"); + + migrationBuilder.DropIndex( + name: "IX_users_AvatarId", + table: "users"); + + migrationBuilder.DropColumn( + name: "AvatarId", + table: "users"); + } + } +} diff --git a/Timeline/Migrations/DatabaseContextModelSnapshot.cs b/Timeline/Migrations/DatabaseContextModelSnapshot.cs index e1de451c..152bdea4 100644 --- a/Timeline/Migrations/DatabaseContextModelSnapshot.cs +++ b/Timeline/Migrations/DatabaseContextModelSnapshot.cs @@ -1,4 +1,5 @@ // +using System; using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Infrastructure; using Microsoft.EntityFrameworkCore.Storage.ValueConversion; @@ -22,6 +23,8 @@ namespace Timeline.Migrations .ValueGeneratedOnAdd() .HasColumnName("id"); + b.Property("AvatarId"); + b.Property("EncryptedPassword") .IsRequired() .HasColumnName("password"); @@ -42,8 +45,36 @@ namespace Timeline.Migrations b.HasKey("Id"); + b.HasIndex("AvatarId"); + b.ToTable("users"); }); + + modelBuilder.Entity("Timeline.Entities.UserAvatar", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnName("id"); + + b.Property("Data") + .IsRequired() + .HasColumnName("data"); + + b.Property("Type") + .IsRequired() + .HasColumnName("type"); + + b.HasKey("Id"); + + b.ToTable("user_avatars"); + }); + + modelBuilder.Entity("Timeline.Entities.User", b => + { + b.HasOne("Timeline.Entities.UserAvatar", "Avatar") + .WithMany() + .HasForeignKey("AvatarId"); + }); #pragma warning restore 612, 618 } } -- cgit v1.2.3