dotnet-dynamic-linq/PoweredSoft.DynamicLinq.Dal/Configurations/Configurations.cs

109 lines
4.6 KiB
C#

using PoweredSoft.DynamicLinq.Dal.Pocos;
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations.Schema;
using System.Data.Entity.ModelConfiguration;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace PoweredSoft.DynamicLinq.Dal.Configurations
{
public class AuthorConfiguration : EntityTypeConfiguration<Author>
{
public AuthorConfiguration() : this("dbo")
{
}
public AuthorConfiguration(string schema)
{
ToTable("Author", schema);
HasKey(t => t.Id);
Property(t => t.Id).HasColumnName("Id").HasColumnType("bigint").IsRequired().HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);
Property(t => t.FirstName).HasColumnType("nvarchar").HasMaxLength(50).IsRequired();
Property(t => t.LastName).HasColumnType("nvarchar").HasMaxLength(50).IsRequired();
HasOptional(t => t.Website).WithMany(t => t.Authors).HasForeignKey(t => t.WebsiteId).WillCascadeOnDelete(false);
}
}
public class PostConfiguration : EntityTypeConfiguration<Post>
{
public PostConfiguration() : this("dbo")
{
}
public PostConfiguration(string schema)
{
ToTable("Post", schema);
HasKey(t => t.Id);
Property(t => t.Id).HasColumnName("Id").HasColumnType("bigint").IsRequired().HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);
Property(t => t.AuthorId).HasColumnName("AuthorId").HasColumnType("bigint").IsRequired();
Property(t => t.Title).HasColumnName("Title").HasColumnType("nvarchar").HasMaxLength(100).IsRequired();
Property(t => t.Content).HasColumnName("Content").HasColumnType("nvarchar(max)").IsRequired();
Property(t => t.CreateTime).HasColumnName("CreateTime").HasColumnType("datetimeoffset").IsRequired();
Property(t => t.PublishTime).HasColumnName("PublishTime").HasColumnType("datetimeoffset").IsOptional();
HasRequired(t => t.Author).WithMany(t => t.Posts).HasForeignKey(t => t.AuthorId).WillCascadeOnDelete(false);
}
}
public class CommentConfiguration : EntityTypeConfiguration<Comment>
{
public CommentConfiguration() : this("dbo")
{
}
public CommentConfiguration(string schema)
{
ToTable("Comment", schema);
HasKey(t => t.Id);
Property(t => t.Id).HasColumnName("Id").HasColumnType("bigint").IsRequired().HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);
Property(t => t.PostId).HasColumnName("PostId").HasColumnType("bigint").IsRequired();
Property(t => t.DisplayName).HasColumnName("DisplayName").HasColumnType("nvarchar").HasMaxLength(100).IsRequired();
Property(t => t.Email).HasColumnName("Email").HasColumnType("nvarchar").IsOptional();
Property(t => t.CommentText).HasColumnName("CommentText").HasColumnType("nvarchar").HasMaxLength(255).IsOptional();
HasRequired(t => t.Post).WithMany(t => t.Comments).HasForeignKey(t => t.PostId).WillCascadeOnDelete(false);
}
}
public class CommentLikeConfiguration : EntityTypeConfiguration<CommentLike>
{
public CommentLikeConfiguration() : this("dbo")
{
}
public CommentLikeConfiguration(string schema)
{
ToTable("CommentLike", schema);
HasKey(t => t.Id);
Property(t => t.Id).HasColumnName("Id").HasColumnType("bigint").IsRequired().HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);
Property(t => t.CommentId).HasColumnName("CommentId").HasColumnType("bigint").IsRequired();
Property(t => t.CreateTime).HasColumnName("CreateTime").HasColumnType("datetimeoffset").IsRequired();
HasRequired(t => t.Comment).WithMany(t => t.CommentLikes).HasForeignKey(t => t.CommentId).WillCascadeOnDelete(false);
}
}
public class WebsiteConfiguration : EntityTypeConfiguration<Website>
{
public WebsiteConfiguration() : this("dbo")
{
}
public WebsiteConfiguration(string schema)
{
ToTable("Website", schema);
HasKey(t => t.Id);
Property(t => t.Id).HasColumnName("Id").HasColumnType("bigint").IsRequired().HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);
Property(t => t.Title).HasColumnName("Title").HasColumnType("nvarchar").HasMaxLength(100).IsRequired();
Property(t => t.Url).HasColumnName("Url").HasColumnType("nvarchar").HasMaxLength(255).IsRequired();
}
}
}