74 lines
3.3 KiB
C#
74 lines
3.3 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();
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
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.ParentCommentId).HasColumnName("ParentCommentId").HasColumnType("bigint").IsOptional();
|
|||
|
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);
|
|||
|
HasOptional(t => t.ParentComment).WithMany(t => t.Comments).HasForeignKey(t => t.ParentCommentId).WillCascadeOnDelete(false);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|