From f657105462b7a8c528b39005d81ffe6141f476a5 Mon Sep 17 00:00:00 2001 From: 杨宇千 Date: Tue, 20 Aug 2019 23:54:22 +0800 Subject: Update Database. --- Timeline/Entities/DatabaseContext.cs | 2 +- .../20190820155221_AddAvatarETag.Designer.cs | 92 +++++++++++++++++++++ .../Migrations/20190820155221_AddAvatarETag.cs | 23 ++++++ ...90820155354_MakeUserNameIndexUnique.Designer.cs | 93 ++++++++++++++++++++++ .../20190820155354_MakeUserNameIndexUnique.cs | 32 ++++++++ .../Migrations/DatabaseContextModelSnapshot.cs | 7 +- 6 files changed, 247 insertions(+), 2 deletions(-) create mode 100644 Timeline/Migrations/20190820155221_AddAvatarETag.Designer.cs create mode 100644 Timeline/Migrations/20190820155221_AddAvatarETag.cs create mode 100644 Timeline/Migrations/20190820155354_MakeUserNameIndexUnique.Designer.cs create mode 100644 Timeline/Migrations/20190820155354_MakeUserNameIndexUnique.cs diff --git a/Timeline/Entities/DatabaseContext.cs b/Timeline/Entities/DatabaseContext.cs index bc06b9df..6e1fc638 100644 --- a/Timeline/Entities/DatabaseContext.cs +++ b/Timeline/Entities/DatabaseContext.cs @@ -43,7 +43,7 @@ namespace Timeline.Entities protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Entity().Property(e => e.Version).HasDefaultValue(0); - modelBuilder.Entity().HasIndex(e => e.Name); + modelBuilder.Entity().HasIndex(e => e.Name).IsUnique(); } public DbSet Users { get; set; } diff --git a/Timeline/Migrations/20190820155221_AddAvatarETag.Designer.cs b/Timeline/Migrations/20190820155221_AddAvatarETag.Designer.cs new file mode 100644 index 00000000..e7c7cb2f --- /dev/null +++ b/Timeline/Migrations/20190820155221_AddAvatarETag.Designer.cs @@ -0,0 +1,92 @@ +// +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("20190820155221_AddAvatarETag")] + partial class AddAvatarETag + { + 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("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("Name"); + + b.ToTable("users"); + }); + + modelBuilder.Entity("Timeline.Entities.UserAvatar", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnName("id"); + + b.Property("Data") + .HasColumnName("data"); + + b.Property("ETag") + .HasColumnName("etag") + .HasMaxLength(30); + + b.Property("LastModified") + .HasColumnName("last_modified"); + + b.Property("Type") + .HasColumnName("type"); + + b.Property("UserId"); + + b.HasKey("Id"); + + b.HasIndex("UserId") + .IsUnique(); + + b.ToTable("user_avatars"); + }); + + modelBuilder.Entity("Timeline.Entities.UserAvatar", b => + { + b.HasOne("Timeline.Entities.User") + .WithOne("Avatar") + .HasForeignKey("Timeline.Entities.UserAvatar", "UserId") + .OnDelete(DeleteBehavior.Cascade); + }); +#pragma warning restore 612, 618 + } + } +} diff --git a/Timeline/Migrations/20190820155221_AddAvatarETag.cs b/Timeline/Migrations/20190820155221_AddAvatarETag.cs new file mode 100644 index 00000000..db352b5d --- /dev/null +++ b/Timeline/Migrations/20190820155221_AddAvatarETag.cs @@ -0,0 +1,23 @@ +using Microsoft.EntityFrameworkCore.Migrations; + +namespace Timeline.Migrations +{ + public partial class AddAvatarETag : Migration + { + protected override void Up(MigrationBuilder migrationBuilder) + { + migrationBuilder.AddColumn( + name: "etag", + table: "user_avatars", + maxLength: 30, + nullable: true); + } + + protected override void Down(MigrationBuilder migrationBuilder) + { + migrationBuilder.DropColumn( + name: "etag", + table: "user_avatars"); + } + } +} diff --git a/Timeline/Migrations/20190820155354_MakeUserNameIndexUnique.Designer.cs b/Timeline/Migrations/20190820155354_MakeUserNameIndexUnique.Designer.cs new file mode 100644 index 00000000..420cd41c --- /dev/null +++ b/Timeline/Migrations/20190820155354_MakeUserNameIndexUnique.Designer.cs @@ -0,0 +1,93 @@ +// +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("20190820155354_MakeUserNameIndexUnique")] + partial class MakeUserNameIndexUnique + { + 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("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("Name") + .IsUnique(); + + b.ToTable("users"); + }); + + modelBuilder.Entity("Timeline.Entities.UserAvatar", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnName("id"); + + b.Property("Data") + .HasColumnName("data"); + + b.Property("ETag") + .HasColumnName("etag") + .HasMaxLength(30); + + b.Property("LastModified") + .HasColumnName("last_modified"); + + b.Property("Type") + .HasColumnName("type"); + + b.Property("UserId"); + + b.HasKey("Id"); + + b.HasIndex("UserId") + .IsUnique(); + + b.ToTable("user_avatars"); + }); + + modelBuilder.Entity("Timeline.Entities.UserAvatar", b => + { + b.HasOne("Timeline.Entities.User") + .WithOne("Avatar") + .HasForeignKey("Timeline.Entities.UserAvatar", "UserId") + .OnDelete(DeleteBehavior.Cascade); + }); +#pragma warning restore 612, 618 + } + } +} diff --git a/Timeline/Migrations/20190820155354_MakeUserNameIndexUnique.cs b/Timeline/Migrations/20190820155354_MakeUserNameIndexUnique.cs new file mode 100644 index 00000000..01d72450 --- /dev/null +++ b/Timeline/Migrations/20190820155354_MakeUserNameIndexUnique.cs @@ -0,0 +1,32 @@ +using Microsoft.EntityFrameworkCore.Migrations; + +namespace Timeline.Migrations +{ + public partial class MakeUserNameIndexUnique : Migration + { + protected override void Up(MigrationBuilder migrationBuilder) + { + migrationBuilder.DropIndex( + name: "IX_users_name", + table: "users"); + + migrationBuilder.CreateIndex( + name: "IX_users_name", + table: "users", + column: "name", + unique: true); + } + + protected override void Down(MigrationBuilder migrationBuilder) + { + migrationBuilder.DropIndex( + name: "IX_users_name", + table: "users"); + + migrationBuilder.CreateIndex( + name: "IX_users_name", + table: "users", + column: "name"); + } + } +} diff --git a/Timeline/Migrations/DatabaseContextModelSnapshot.cs b/Timeline/Migrations/DatabaseContextModelSnapshot.cs index 0eb85997..4941321c 100644 --- a/Timeline/Migrations/DatabaseContextModelSnapshot.cs +++ b/Timeline/Migrations/DatabaseContextModelSnapshot.cs @@ -43,7 +43,8 @@ namespace Timeline.Migrations b.HasKey("Id"); - b.HasIndex("Name"); + b.HasIndex("Name") + .IsUnique(); b.ToTable("users"); }); @@ -57,6 +58,10 @@ namespace Timeline.Migrations b.Property("Data") .HasColumnName("data"); + b.Property("ETag") + .HasColumnName("etag") + .HasMaxLength(30); + b.Property("LastModified") .HasColumnName("last_modified"); -- cgit v1.2.3