反正有没有加快SQL Server管理对象遍历现有数据库的速度?

Sco*_*ell 3 .net c# sql-server smo

我目前正在使用SMO和C#来遍历数据库以创建表示两个数据库的各个方面的设置树,然后比较这些树以查看它们在何处以及如何不同.

问题是,对于2个大小合理的数据库,在本地抓取它们需要差不多10分钟,并收集我希望比较的表/列/存储过程信息.

SMO是否有更好的接口以这种方式访问​​数据库?我想不包括任何其他依赖项,但我会把这种痛苦提高50%的速度.下面是我如何枚举表和列的示例.

        Microsoft.SqlServer.Management.Smo.Database db = db_in;
        foreach (Table t in db.Tables)
        {
            if (t.IsSystemObject == false)
            {

                foreach (Column c in t.Columns)
                {
                }                    
            }
        }
Run Code Online (Sandbox Code Playgroud)

dev*_*vio 6

尝试强制SMO一次读取所有必需的字段,而不是查询访问.有关更多信息,请参阅此博客


编辑:链接已死,但我在archive.org上找到了该页面.这是相关的代码:

Server server = new Server();

// Force IsSystemObject to be returned by default.
server.SetDefaultInitFields(typeof(StoredProcedure), "IsSystemObject");

StoredProcedureCollection storedProcedures = server.Databases["AdventureWorks"].StoredProcedures;

foreach (StoredProcedure sp in storedProcedures) {
    if (!sp.IsSystemObject) {
        // We only want user stored procedures
    }
}
Run Code Online (Sandbox Code Playgroud)

  • 这是一个显着的加速,不需要像上面的选项那样对方法进行大幅改变,谢谢。 (2认同)
  • 过去需要 10 分钟的任务现在只需约 40 秒即可执行 (2认同)