首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jbogard/Respawn,如何重新播种sql?

jbogard/Respawn,如何重新播种sql?
EN

Stack Overflow用户
提问于 2021-09-20 15:49:20
回答 1查看 78关注 0票数 0

无法理解如何通过Respawn重新设定种子。ReseedSql属性是私有集。如何设置此属性?我没有看到一个带有参数来设置私有setter的构造函数。我应该重写检查点类吗?

代码语言:javascript
复制
public class Checkpoint
    {
        private GraphBuilder _graphBuilder;
        private IList<TemporalTable> _temporalTables = new List<TemporalTable>();

        public string[] TablesToIgnore { get; set; } = new string[0];
        public string[] TablesToInclude { get; set; } = new string[0];
        public string[] SchemasToInclude { get; set; } = new string[0];
        public string[] SchemasToExclude { get; set; } = new string[0];
        public string DeleteSql { get; private set; }
        public string ReseedSql { get; private set; }
        public bool CheckTemporalTables { get; set; } = false;
        internal string DatabaseName { get; private set; }
        public bool WithReseed { get; set; } = false;
        public IDbAdapter DbAdapter { get; set; } = Respawn.DbAdapter.SqlServer;

        public int? CommandTimeout { get; set; }

        
        }
    }
EN

回答 1

Stack Overflow用户

发布于 2021-11-14 21:34:11

如果重新设定种子意味着在重置期间重置标识列种子值,那么只需将Checkpoint.WithReseed设置为true即可。

有关实现细节和讨论,请参阅此PR和此issue

但是,如果重新设定种子意味着将数据恢复到其初始状态,而不仅仅是删除它,那么您可能需要签出Reseed库。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69257387

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档