DocSpace-client/common/ASC.Core.Common/EF/Model/DbWebstudioIndex.cs

66 lines
2.2 KiB
C#
Raw Normal View History

2020-08-21 02:34:37 +00:00
using Microsoft.EntityFrameworkCore;
using System;
2020-01-24 13:07:51 +00:00
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
namespace ASC.Core.Common.EF.Model
{
[Table("webstudio_index")]
2020-04-27 16:59:52 +00:00
public class DbWebstudioIndex : BaseEntity
2020-01-24 13:07:51 +00:00
{
[Key]
[Column("index_name")]
public string IndexName { get; set; }
[Column("last_modified")]
public DateTime LastModified { get; set; }
2020-04-27 16:59:52 +00:00
public override object[] GetKeys() => new[] { IndexName };
2020-01-24 13:07:51 +00:00
}
2020-08-21 02:34:37 +00:00
public static class DbWebstudioIndexExtension
{
public static ModelBuilder MySqlAddDbWebstudioIndex(this ModelBuilder modelBuilder)
{
modelBuilder.Entity<DbWebstudioIndex>(entity =>
{
entity.HasKey(e => e.IndexName)
.HasName("PRIMARY");
entity.ToTable("webstudio_index");
entity.Property(e => e.IndexName)
.HasColumnName("index_name")
.HasColumnType("varchar(50)")
.HasCharSet("utf8")
.HasCollation("utf8_general_ci");
entity.Property(e => e.LastModified)
.HasColumnName("last_modified")
.HasColumnType("timestamp")
.HasDefaultValueSql("CURRENT_TIMESTAMP")
.ValueGeneratedOnAddOrUpdate();
});
return modelBuilder;
}
public static ModelBuilder PgSqlAddDbWebstudioIndex(this ModelBuilder modelBuilder)
{
modelBuilder.Entity<DbWebstudioIndex>(entity =>
{
entity.HasKey(e => e.IndexName)
.HasName("webstudio_index_pkey");
entity.ToTable("webstudio_index", "onlyoffice");
entity.Property(e => e.IndexName)
.HasColumnName("index_name")
.HasMaxLength(50);
entity.Property(e => e.LastModified)
.HasColumnName("last_modified")
.HasDefaultValueSql("CURRENT_TIMESTAMP");
});
return modelBuilder;
}
}
2020-01-24 13:07:51 +00:00
}