自动输出SQLServer存储过程依赖列表到EXCEL文件

来源:计算机等级考试    发布时间:2012-08-27    计算机等级考试视频    评论

  需求
  现在数据库很老很大,表不多,200来个,但数据量很大:最大的数据表2亿6千万条,每天增加50多w,925个存储过程。
  系统大,耦合度很高,牵一发而动全身。人员变动频繁,接手的人员要在修改之前,就得花相当长的时间来分析关联性。
  所以,印度资深系统分析员要求我在一个EXCEL文件中,把925个存储过程的所有依赖的对象(表、函数、视图、存储过程等等)都列举出来。
  分析
  手工逐个打开存储过程去做,对写软件的人来说是很傻的事情,一般重复性工作,如果预计耗时超过3分钟,我就会卷起袖子写个代码。
  工作内容有3部分:
  1.获取所有的存储过程。我们可以用sysobjects这个系统表,它存储了所有的表、存储过程、视图、函数等。其中存储过程的xtype是P。另外说一下,如果是CLR存储过程,类型是PC。
  2. 获取某存储过程所依赖的对象,当然是先google了。很久之前我就知道可以用系统存储过程sp_depends来获取,不过还是应该看看还有什么更好的办法。首先我发现这个:http://www.mssqltips.com/tip.asp?tip=1294 。作者研究出4种办法:INFORMATION_SCHEMA.ROUTINES/sp_depends/syscomments/sp_MSdependencies。其中就有我一直在用的sp_depends。其它办法有的霸王硬上弓:用charindex来遍历存储过程内容,或者用LIKE来判断。。。。。我服了,写代码的风格千差万别,一些是[Foo],一些是Foo,而且不同的存储过程名称可能存在完全给另外一个包含,譬如Foo Foo1 AFoo等。
  看完之后,我还是觉得使用sp_depends相对靠谱。为什么说“相对靠谱”呢?因为我发现它某些情况下也会没有返回所有依赖的,这应该是SQL Server的bug吧?如果要把所有依赖都找回来,你可以去修改被遗忘的引用存储过程,随便加个空行,运行(就是保存结果),你会发现之前没有显示的依赖终于出现了。而且,sp_depends会输出重复的记录。。。所以我们在代码中要剔除掉。
  3. 既然是输出到EXCEL文件,我们就需要找相应的代码。在这个网站已经有很多EXCEL文件生成的代码了,譬如NPOI。我最后采用了GemBox的,因为够轻便。本来想用更轻便的MyXLS,但发现它不支持单背景色。当然你也可以用别的,譬如XML格式的EXCEL文件,这是你个人的选择了。
  解决了上述的2个问题,我们就可以大干一场了。我还是采用VS2005+C#2.0,因为公司还是在用古老的XP搭配VS2005,鬼佬国家要求什么都正版,自然不会像我们在中国那样随便就升级到2010了。所以只能放弃LINQ,老老实实地写冗余的代码了。
  以下代码没有什么特别的,都是循环所有存储过程,然后循环每个存储过程的依赖对象,然后排序输出(先按照类型,然后按照名称)。代码也写得很quick and dirty,10来分钟的事情,不要跟代码规范较真。
  using System;
  using System.Collections.Generic;
  using System.Text;
  using System.IO;
  using System.Drawing;
  using System.Data;
  using System.Data.SqlClient;
  using GemBox.Spreadsheet;
  namespace SQLServerDocumenter
  {
  class Program
  {
  static void Main(string[] args)
  {
  if (args.Length == 0)
  {
  args = new string[3];
  args[0] = "FooDB";
  args[1] = "FooServer";
  args[2] = "FooPassword";
  }
  string db = args[0];
  string dataSource = args.Length > 1 ? args[1] : string.Empty;
  string password = args.Length > 2 ? args[2] : string.Empty;
  ExcelFile xls = new ExcelFile();
  ExcelWorksheet sheet = xls.Worksheets.Add("Dictionary");
  CellStyle typeStyle = new CellStyle(xls);
  typeStyle.FillPattern.SetSolid(Color.Yellow);
  typeStyle.Font.Color = Color.Black;
  typeStyle.Font.Weight = ExcelFont.BoldWeight;
  CellStyle nameStyle = new CellStyle(xls);
  nameStyle.FillPattern.SetSolid(Color.DarkGray);
  nameStyle.Font.Color = Color.Black;
  nameStyle.Font.Weight = ExcelFont.BoldWeight;
  CellStyle itemStyle = new CellStyle(xls);
  itemStyle.FillPattern.SetSolid(Color.LightGray);
  itemStyle.Font.Color = Color.Black;

上一页123下一页

视频学习

我考网版权与免责声明

① 凡本网注明稿件来源为"原创"的所有文字、图片和音视频稿件,版权均属本网所有。任何媒体、网站或个人转载、链接转贴或以其他方式复制发表时必须注明"稿件来源:我考网",违者本网将依法追究责任;

② 本网部分稿件来源于网络,任何单位或个人认为我考网发布的内容可能涉嫌侵犯其合法权益,应该及时向我考网书面反馈,并提供身份证明、权属证明及详细侵权情况证明,我考网在收到上述法律文件后,将会尽快移除被控侵权内容。

最近更新

社区交流

考试问答