当前位置: 首页>>代码示例>>C#>>正文


C# Schema.GetDatabaseTables方法代码示例

本文整理汇总了C#中Schema.GetDatabaseTables方法的典型用法代码示例。如果您正苦于以下问题:C# Schema.GetDatabaseTables方法的具体用法?C# Schema.GetDatabaseTables怎么用?C# Schema.GetDatabaseTables使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Schema的用法示例。


在下文中一共展示了Schema.GetDatabaseTables方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: SyncEnums

        private static SqlPreCommand SyncEnums(Schema schema, Table table, Dictionary<string, Entity> current, Dictionary<string, Entity> should)
        {
            var deletes = Synchronizer.SynchronizeScript(
                       should,
                       current,
                       null,
                       (str, c) => table.DeleteSqlSync(c, comment: c.toStr),
                       null, Spacing.Double);

            var moves = Synchronizer.SynchronizeScript(
                       should,
                       current,
                       null,
                       null,
                       (str, s, c) =>
                       {
                           if (s.id == c.id)
                               return table.UpdateSqlSync(c, comment: c.toStr);

                           var insert = table.InsertSqlSync(s);

                           var move = (from t in schema.GetDatabaseTables()
                                       from col in t.Columns.Values
                                       where col.ReferenceTable == table
                                       select new SqlPreCommandSimple("UPDATE {0} SET {1} = {2} WHERE {1} = {3} -- {4} re-indexed"
                                           .FormatWith(t.Name, col.Name, s.Id, c.Id, c.toStr)))
                                        .Combine(Spacing.Simple);

                           var delete = table.DeleteSqlSync(c, comment: c.toStr);

                           return SqlPreCommand.Combine(Spacing.Simple, insert, move, delete);
                       }, Spacing.Double);

            var creates = Synchronizer.SynchronizeScript(
                   should,
                   current,
                  (str, s) => table.InsertSqlSync(s),
                   null,
                   null, Spacing.Double);

            return SqlPreCommand.Combine(Spacing.Double, deletes, moves, creates);
        }
开发者ID:signumsoftware,项目名称:framework,代码行数:42,代码来源:SchemaSynchronizer.cs


注:本文中的Schema.GetDatabaseTables方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。