Refactoring, database structure changed
This commit is contained in:
54
WatchIt.Database/Configuration/People/PersonConfiguration.cs
Normal file
54
WatchIt.Database/Configuration/People/PersonConfiguration.cs
Normal 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
|
||||
}
|
||||
@@ -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
|
||||
}
|
||||
@@ -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
|
||||
}
|
||||
Reference in New Issue
Block a user