• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

使用SQL DMO从SQL Server中获取信息

发布: 2007-6-21 12:06 | 作者:   | 来源:   | 查看: 17次 | 进入软件测试论坛讨论

领测软件测试网

   
  提要:
  ms sql server提供了一个非常方便的COM组件“SQLDMO”来帮助我们获取和管理SQL Server。在这里提供一些想法和实现。
  系统要求:
  windows2000server
  vs.net rc3
  sql server 2000
  正文:

  1.在.NET中使用sqldmo.dll
  path :>tlbimp sqldmo.dll /out : rc3sqldmo.dll
  创建一个新的C#项目(winform, library....),添加引用,选择Browse,找到rc3sqldmo.dll,加入。
  2.查看rc3sqldmo.dll的结构
  打开object view,选择rc3sqldmo,你能浏览所有的属性、方法和事件的定义。
  3.使用rc3sqldmo
  获得连接:
  rc3sqldmo.sqlserver2 mysqlsvr = new rc3sqldmo.sqlserver2class();
  
  mysqlsvr .connect("sqlservername","uid","pws");
  
  获得数据库信息:
  rc3sqldmo.databases mydbs=mysqlsvr.databases;
  rc3sqldmo.database2 mydb =new rc3sqldmo.database2class();
  mydb=mydbs.item("dbname","owner"); 或mydb=mysqlsvr.databases.item("dbname","owner");
  
  获得表和字段的信息:
  rc3sqldmo.Tables mytbls= mysqlsvr.databases.item("dbname","owner").tables;
  rc3sqldmo.table2 mytbl = new rc3sqldmo.table2class();
  mytbl = mytbls.item("tablename","owner");或
  mytbl = mysqlsvr.databases.item("dbname","owner").tables.item("tablename","owner");
  string[3] mylist = new string[3];
  rc3sqldmo.column2 myfield = new rc3sqldmo.column2class();
  foreach(object o in mytbl.columns)
  {
  myfield = (rc3sqldmo.column2) o;
  mylist[0]=myfield.name;
  mylist[1] = myfield.datatype;
  mylist[2] =myfield.length.tostring();
  }
  
  获得存储过程的信息:
  rc3sqldmo.storedprecudure2 mysp = new rc3sqldmo.storedprecudure2class();
  mysp =mysqlsvr.batabase.itrm("dbname",owner).storedprecudures.item[B("spname",owner)]
  
  用途的讨论:
  动态管理sql server
  动态获得table,storedprecudure的结构信息
  还能增加,修改所有sql server object的内容。

延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网