Creation of EF Core Migrations - these execute using EF Tools, but are not integrated to run programmatically
This commit is contained in:
@ -0,0 +1,42 @@
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Microsoft.EntityFrameworkCore.Migrations.Operations;
|
||||
using Microsoft.EntityFrameworkCore.Migrations.Operations.Builders;
|
||||
using Oqtane.Migrations.Extensions;
|
||||
|
||||
// ReSharper disable MemberCanBePrivate.Global
|
||||
// ReSharper disable UnusedAutoPropertyAccessor.Global
|
||||
|
||||
namespace Oqtane.Migrations.EntityBuilders
|
||||
{
|
||||
public class TenantEntityBuilder : AuditableBaseEntityBuilder<TenantEntityBuilder>
|
||||
{
|
||||
private const string _entityTableName = "Tenant";
|
||||
private readonly PrimaryKey<TenantEntityBuilder> _primaryKey = new("PK_Tenant", x => x.TenantId);
|
||||
|
||||
public TenantEntityBuilder(MigrationBuilder migrationBuilder): base(migrationBuilder)
|
||||
{
|
||||
EntityTableName = _entityTableName;
|
||||
PrimaryKey = _primaryKey;
|
||||
}
|
||||
|
||||
protected override TenantEntityBuilder BuildTable(ColumnsBuilder table)
|
||||
{
|
||||
TenantId = table.AddAutoIncrementColumn("TenantId");
|
||||
Name = table.AddStringColumn("Name", 100);
|
||||
DBConnectionString = table.AddStringColumn("DBConnectionString", 1024);
|
||||
Version = table.AddStringColumn("Version", 50, true);
|
||||
|
||||
AddAuditableColumns(table);
|
||||
|
||||
return this;
|
||||
}
|
||||
|
||||
public OperationBuilder<AddColumnOperation> TenantId { get; private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> Name { get;private set; }
|
||||
|
||||
public OperationBuilder<AddColumnOperation> DBConnectionString { get; private set;}
|
||||
|
||||
public OperationBuilder<AddColumnOperation> Version { get; private set; }
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user