Refactoring, database structure changed

This commit is contained in:
2025-03-03 00:56:32 +01:00
Unverified
parent d3805ef3db
commit c603c41c0b
913 changed files with 21764 additions and 32775 deletions

View File

@@ -0,0 +1,54 @@
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Metadata.Builders;
using WatchIt.Database.Model.People;
namespace WatchIt.Database.Configuration.People;
public class PersonConfiguration : IEntityTypeConfiguration<Person>
{
#region PUBLIC METHODS
public void Configure(EntityTypeBuilder<Person> builder)
{
builder.ToTable("People", "people");
// Id
builder.HasKey(x => x.Id);
builder.HasIndex(x => x.Id)
.IsUnique();
builder.Property(x => x.Id)
.IsRequired()
.UseIdentityAlwaysColumn();
// Name
builder.Property(x => x.Name)
.HasMaxLength(100)
.IsRequired();
// Full name
builder.Property(x => x.FullName)
.HasMaxLength(200);
// Description
builder.Property(x => x.Description)
.HasMaxLength(1000);
// Birth date
builder.Property(x => x.BirthDate);
// Death date
builder.Property(x => x.DeathDate);
// Gender
builder.HasOne(x => x.Gender)
.WithMany(x => x.People)
.HasForeignKey(x => x.GenderId);
builder.Property(x => x.GenderId);
// Version
builder.Property(b => b.Version)
.IsRowVersion();
}
#endregion
}

View File

@@ -0,0 +1,36 @@
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Metadata.Builders;
using WatchIt.Database.Model.Media;
using WatchIt.Database.Model.People;
namespace WatchIt.Database.Configuration.People;
public class PersonPictureConfiguration : ImageEntityConfiguration<PersonPicture>
{
#region PUBLIC METHODS
public override void Configure(EntityTypeBuilder<PersonPicture> builder)
{
builder.ToTable("PersonPictures", "people");
// Person
builder.HasKey(x => x.PersonId);
builder.HasIndex(x => x.PersonId)
.IsUnique();
builder.HasOne(x => x.Person)
.WithOne(x => x.Picture)
.HasForeignKey<PersonPicture>(x => x.PersonId)
.IsRequired();
builder.Property(x => x.PersonId)
.IsRequired();
// Version
builder.Property(b => b.Version)
.IsRowVersion();
// Generic properties
base.Configure(builder);
}
#endregion
}

View File

@@ -0,0 +1,33 @@
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Metadata.Builders;
using WatchIt.Database.Model.People;
namespace WatchIt.Database.Configuration.People;
public class PersonViewCountConfiguration : ViewCountEntityConfiguration<PersonViewCount>
{
#region PUBLIC METHODS
public override void Configure(EntityTypeBuilder<PersonViewCount> builder)
{
builder.ToTable("PersonViewCounts", "people");
builder.HasKey(x => new { x.PersonId, x.Date });
// Medium
builder.HasOne(x => x.Person)
.WithMany(x => x.ViewCounts)
.HasForeignKey(x => x.PersonId)
.IsRequired();
builder.Property(x => x.PersonId)
.IsRequired();
// Version
builder.Property(b => b.Version)
.IsRowVersion();
// Generic properties
base.Configure(builder);
}
#endregion
}