-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathDataModel_Create.cs
More file actions
83 lines (72 loc) · 3.14 KB
/
DataModel_Create.cs
File metadata and controls
83 lines (72 loc) · 3.14 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
using ModelSync.Abstract;
using ModelSync.Services;
using System;
using System.Collections.Generic;
using System.Data;
using System.Reflection;
using System.Threading.Tasks;
namespace ModelSync.Models
{
public partial class DataModel
{
public void ImportTypes(IEnumerable<Type> types, string defaultSchema = "dbo", string defaultIdentityColumn = "Id")
{
var model = new AssemblyModelBuilder().GetDataModel(types, defaultSchema, defaultIdentityColumn);
ImportModel(model);
}
public void ImportTypes(Assembly assembly, string defaultSchema = "dbo", string defaultIdentityColumn = "Id")
{
var model = new AssemblyModelBuilder().GetDataModel(assembly, defaultSchema, defaultIdentityColumn);
ImportModel(model);
}
private void ImportModel(DataModel model)
{
Schemas = model.Schemas;
Tables = model.Tables;
ForeignKeys = model.ForeignKeys;
Errors = model.Errors;
}
public async Task DeployAsync(IDbConnection connection, SqlDialect dialect)
{
var createTables = await ScriptCreateTablesAsync(connection, dialect);
await dialect.ExecuteAsync(connection, createTables);
}
public static async Task CreateTablesAsync(IEnumerable<Type> modelTypes, IDbConnection connection, SqlDialect dialect = null, string defaultSchema = "dbo", string defaultIdentityColumn = "Id")
{
var dataModel = AssemblyModelBuilder.GetDataModelFromTypes(modelTypes, defaultSchema, defaultIdentityColumn);
if (dialect == null) dialect = new SqlServerDialect();
var script = await dataModel.ScriptCreateTablesAsync(connection, dialect);
await dialect.ExecuteAsync(connection, script);
}
public static async Task CreateTablesAsync(IEnumerable<Type> modelTypes, Func<IDbConnection> getConnection, SqlDialect dialect = null, string defaultSchema = "dbo", string defaultIdentityColumn = "Id")
{
using (var cn = getConnection.Invoke())
{
await CreateTablesAsync(modelTypes, cn, dialect, defaultSchema, defaultIdentityColumn);
}
}
public async Task<IEnumerable<ScriptAction>> ScriptCreateTablesAsync(IDbConnection connection, SqlDialect dialect)
{
List<ScriptAction> results = new List<ScriptAction>();
async Task AddObjectsAsync(IEnumerable<DbObject> objects)
{
foreach (var obj in objects)
{
if (!await obj.ExistsAsync(connection, dialect))
{
results.Add(new ScriptAction()
{
Object = obj,
Commands = obj.CreateStatements(),
Type = ActionType.Create
});
}
}
}
await AddObjectsAsync(Schemas);
await AddObjectsAsync(Tables);
await AddObjectsAsync(ForeignKeys);
return results;
}
}
}