OpenAuth.Net/CodeSmith/CSharp/Internal/Context.Generated.cst
2020-10-22 14:59:36 +08:00

81 lines
2.6 KiB
Plaintext

<%@ Template Language="C#" TargetLanguage="C#" Debug="True" Encoding="UTF-8" %>
<%@ Assembly Src="../Internal/Model.cs" %>
<%@ Assembly Src="../Internal/Extensions.cs" %>
<%@ Import Namespace="System.Collections.Generic" %>
<%@ Import Namespace="System.Linq" %>
<%@ Import Namespace="System.Text" %>
<%@ Import Namespace="System.Text.RegularExpressions" %>
<%@ Import Namespace="SchemaMapper" %>
<%@ Property Name="WholeDb"
Type="System.Boolean"
Category="1.Database"
Default="true"
Description="是否为整个数据库" %>
<%@ Property Name="SourceDatabase"
Type="SchemaExplorer.DatabaseSchema"
Category="1.Database"
Description="The source database." %>
<%@ Property Name="SourceTables"
Type="SchemaExplorer.TableSchemaCollection"
Category="1.Database" Description="选择部分表" %>
<%@ Property Name="ContextNamespace" Type="System.String" %>
<%@ Property Name="EntityNamespace" Type="System.String" %>
using Microsoft.EntityFrameworkCore;
using <%= EntityNamespace %>;
namespace <%= ContextNamespace %>
{
<%
string dbContextName;
if(WholeDb){
dbContextName = SourceDatabase.Name.ToSafeName();
}
else{
dbContextName = SourceTables.First().Database.Name.ToSafeName();
}
dbContextName = StringUtil.ToPascalCase(dbContextName);
Response.WriteLine(" public partial class "+ dbContextName +"Context: DbContext");
%>
{
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
//当主键为联合主键时,需要把这里的内容拷贝到对应的位置
<%
TableSchemaCollection tables;
if(WholeDb){
tables = SourceDatabase.Tables;
}
else{
tables = SourceTables;
}
foreach(TableSchema table in tables)
{
if(table.PrimaryKeys.Count <=1) continue;
var keys = string.Join(",", table.Columns.Where(u=>u.IsPrimaryKeyMember==true)
.Select(u =>"c."+u.Name));
Response.WriteLine(" modelBuilder.Entity<"+table.Name+">()");
Response.WriteLine(" .HasKey(c => new { "+keys+" });");
}
%>
}
<%
foreach(TableSchema table in tables)
{
Response.WriteLine(" public virtual DbSet<"+table.Name+"> "+StringUtil.ToPascalCase(StringUtil.ToPlural(table.Name))+" { get; set; }");
}
%>
}
}