编写数据库脚本
作者:未知 来源:转载 发布时间:2005-7-20 11:38:54 发布人:acx
我在“If It Moves, script It”(英文)这篇文章中曾谈到,如何使用“Windows script Host(WSH)”( Windows 脚本主机) 管理 Windows 和 Windows 中的应用程序。文中的大多数示例都是基于管理 Windows 操作系统自身的,并不基于在该操作系统下运行的应用程序。为迎接新千年,我想我应该谈谈,如何在众多显露可脚本化接口的应用程序中使用脚本。这次只涉及“SQL Server”。在以后的几个月中,我将着重谈 Exchange、Office 和“系统管理服务器”。
您可以通过使用“分布式管理对象”、“数据转换服务”和新的“SQL Server XML”实现,将脚本用于“SQL Server”。
许多人都能够通过“Active Data Object(ADO)”和“Active Server Page (ASP)”技术访问数据库了。ADO 在帮助您查询和更新数据库方面做了大量的工作 — 但在备份(Y2K 问题带给我们的警惕)或是数据库之间的传输数据方面,其表现又如何呢?而这时就非涉及到 XML 不可了。
在此,我将告诉您如何通过使用 ADO 的伴随技术 - 特别是“分布式管理对象”、“数据转换服务”和新的“SQL Server XML”实现,将脚本用于“SQL Server”。
分布式管理对象
“分布式管理对象 (DMO)”是一组 COM 对象,它将“SQL Server”数据库和复制管理封装在一起。这意味着您可以编写一个 WSH 脚本,将特定表中的所有数据都复制到用制表符分隔的文件中,这有助于大量数据的移动。我之所以选择这个示例,是因为它的代码编写起来简单,但 DMO 允许您获取“SQL Server”中的每个对象,使您能够编写出一些非常优秀而有意义的管理脚本。
DMO 的关键是 SQLDMO.SQLServer 对象,它是基本的对象,它允许您连接到服务器并获取所有可用对象。在这种情况下,我将使用 Database 集合来选择数据库,然后从 table 集合访问要转储到文件的表。如果不提供数据库,将出现错误消息,并且脚本也就结束了。如果不提供表名,脚本将在数据库所有的表中循环,并导出非系统表。如果提供了数据库,它就导出该表。该示例虽然功能有限,但它为“SQL Server”提供了基于命令行的简单的导出实用程序,您可以以它为根据。
现在先看一段代码:
'声明与 sql 谈话时使用的变量
Dim oServer ' SQL Server 对象
Dim oDatabase ' 要使用的目标数据库
Dim oBCP ' BCP 对象
Dim nRows ' 从 bcp 返回的行数
dim table ' 表对象
on error resume next
' 第一个参数必须是数据库
if Wscript.Arguments(0) = "" then<br/>Wscript.Echo "您没有提供要连接的数据库"<br/>Wscript.Quit<br/>end if<br/>' 创建 SQL DMO 的实例<br/>Set oServer = CreateObject("SQLDMO.SQLServer")<br/>' 创建 SQL DMO Bulkcopy 对象的实例<br/>Set oBCP = CreateObject("SQLDMO.BulkCopy")<br/>oServer.EnableBcp = True<br/>' 登录到本地服务器<br/>' 希望您已经更改了 sa 口令!!<br/>oServer.Connect ".", "sa" <br/>' 连接到提供的数据库<br/>Set oDatabase = oServer.Databases(Wscript.Arguments(0))<br/><br/>' 将分隔符设置为逗号<br/>oBCP.ColumnDelimiter = vbComma<br/>' 将文件类型设置为以逗号分隔<br/>oBCP.DataFileType = SQLDMODataFile_CommaDelimitedChar<br/>oBCP.ImportRowsPerBatch = 1000<br/>oBCP.MaximumErrorsBeforeAbort = 1<br/>BCP.RowDelimiter = vbCrLf<br/>oBCP.ServerBCPDataFileType = SQLDMOBCPDataFile_Char<br/>oBCP.UseExistingConnection = True<br/>' 如果未提供表,则转储所有的表<br/>f wscript.Arguments(1) = "" then<br/>for each table in oDatabase.tables<br/>' 确保该表不是系统表<br/>if table.systemobject = false then<br/>oBCP.DataFilePath = table.name & ".csv"<br/>nRows = table.ExportData(oBCP)<br/>wscript.Echo nRows & " rows exported from " & table.name<br/>end if<br/>next<br/>else<br/>' 设置输出文件<br/>oBCP.DataFilePath = wscript.Arguments(1) & ".csv" <br/>nRows = oDatabase.Tables(wscript.arguments(1)).ExportData(oBCP)<br/>wscript.Echo nRows & " rows exported from " & wscript.arguments(1)<br/>end if<br/>DMO 的全部内容要比本文介绍的多得多,但我希望本文能给您一些感性认识:用某些简单的 WSH 脚本和 DMO 可以做些什么。您可以下载我的示例(英文)。有关 DMO 的详细信息,请访问 http://msdn.microsoft.com/library/psdk/sql/9_dmoc01.htm(英文)。 <br/><br/>数据转换服务<br/>导出到 Comma Separated 文件 (CSV),可以作为将数据导出到 SQL 和从 SQL 导入的起点,但这不象是尖端科技(太过于 20 世纪了,您不觉得吗?)。“SQL Server 7.0”以“数据转换服务 (DTS)”的形式,提供了相当完善的导入和导出机制。幸运的是,脚本在“SQL Server”的这个新领域中仍有一席之地,因此,您可以用“Visual Basic(R) 脚本编辑 (VBscript)”、“Jscript(R)”或“Perl”的技术来扩展 DTS 的能力。<br/><br/>DTS 的设置非常简单,特别是在使用“SQL ServerEnterprise Manager”的时候。在默认情况下,“SQL Server”有一个定义的文件夹,可存储任何转换,而且“Enterprise Manager”提供了创建和编辑 DTS 程序包的大的图形用户界面 (GUI)。在下面的示例中,我选择了已由 sqlexport.wsf 文件创建的 employees.csv 文件和“SQL Server”中的一个新表。DTA 程序包将创建该表,加载到 Text 文件中,然后运行某个脚本,将数据转换到“SQL Server”的表中。<br/><img SRC="http://www.newasp.net/Article/UploadPic/2005-4/200549161415799.gif" style="CURSOR: pointer" border="0" onload="return imgzoom(this,550);" onclick="javascript:window.open(this.src);" style="cursor: pointer;"/></IMG><br/>DTS 程序包中的转换,使脚本在整个转换过程中保持运行状态。“SQL Enterprise Manager”提供的简单的脚本编辑器,有一个语法分析脚本按钮。在运行脚本之前,该按钮将警告您脚本中的错误。在转换过程中,该脚本使用 VBscript 的 Cint 功能,将 employeeid 和 deptid 的输入转换为 int,并将所有的电子邮件地址转换为小写字母。<br/><br/>'**********************************************************************<br/>' Visual Basic 转换脚本<br/>' 把每个源列复制到<br/>' 目标列<br/>'***********************************************************************<br/>Function Main()<br/>DTSDestination("EmployeeID") = cint(DTSSource("Col001"))<br/>DTSDestination("FirstName") = DTSSource("Col002")<br/>DTSDestination("LastName") = DTSSource("Col003")<br/>DTSDestination("email") = lcase(DTSSource("Col004"))<br/>DTSDestination("extension") = DTSSource("Col005")<br/>DTSDestination("office") = DTSSource("Col006")<br/>DTSDestination("DeptID") = cint(DTSSource("Col007"))<br/>Main = DTSTransformStat_OK<br/>End Function<br/>用 DTS,能够采用某些完善的导入/导出机制,并使您能够在转换的任何一步中使用脚本。重要的是,要注意脚本可能不是操作数据的最佳方式 — 尤其是您的数据集很大的话。如果您有大量数</p></div><p align="center"><b><font color="red">[1]</font> <a href="200507205777_2.html">[2]</a> <a href="200507205777_2.html">下一页</a></b></p> <p><a href="javascript:window.open('http://shuqian.qq.com/post?from=3&title='+encodeURIComponent(document.title)+'&uri='+encodeURIComponent(document.location.href)+'&jumpback=2&noui=1','favit','width=930,height=470,left=50,top=50,toolbar=no,menubar=no,location=no,scrollbars=yes,status=yes,resizable=yes');void(0)" style="text-decoration:none;color:#155da5;display:block;background:url('http://shuqian.qq.com/img/add.gif') no-repeat 0px 0px;height:23px;width:300px;padding:2px 2px 0px 20px;font-size:14px;">将本文收藏到QQ书签与更多好友分享</a></p> <p><script language=javascript src=/wz/sg.JS></script></p> </div> </div> <div class="user_nav"><p>上一篇:<a href="/Article/10/130/2005/200507205776.html">aspemail组件的应用</a></p> <p>下一篇:<a href="/Article/10/130/2005/200507205778.html">跟我学做最强功能的网站统计</a> <script language=javascript src=/wz/wangzhai/wangzhai.js></script></p> </div> <div class="list_menu_b"> <div class="left"> <h2>热门阅读 »</h2> <ul> <li class="showlist1">· <a href="/Article/10/138/2005/200507256912.html" title="注册码大全二">注册码大全二</a></li> <li class="showlist2">· <a href="/Article/10/138/2005/200507256914.html" title="注册码大全四">注册码大全四</a></li> <li class="showlist1">· <a href="/Article/10/138/2005/200507256911.html" title="注册码大全一">注册码大全一</a></li> <li class="showlist2">· <a href="/Article/196/197/2005/2005081911736.html" title="要10G免费网络硬盘的请进来!">要10G免费网络硬盘的请进来!...</a></li> <li class="showlist1">· <a href="/Article/206/2007/2007030319347.html" title="通过google 赶快来赚美金">通过google 赶快来赚美金</a></li> <li class="showlist2">· <a href="/Article/10/138/2005/200507256919.html" title="注册码大全十">注册码大全十</a></li> <li class="showlist1">· <a href="/Article/10/138/2005/200507256913.html" title="注册码大全三">注册码大全三</a></li> <li class="showlist2">· <a href="/Article/14/253/2005/2005092114218.html" title="头像-qq头像(qq新头像)4">头像-qq头像(qq新头像)4</a></li> <li class="showlist1">· <a href="/Article/13/150/2006/2006022316028.html" title="让你轻松架设FTP服务器1">让你轻松架设FTP服务器1</a></li> <li class="showlist2">· <a href="/Article/14/244/2005/2005092014121.html" title="梦幻背景图片7">梦幻背景图片7</a></li> </ul> </div> <div class="right"> <h2>相关阅读 »</h2> <ul> <li class="showlist11">· <a href="/Article/13/151/2005/200507204673.html" target="_blank" title="小试Samba服务器(2)">小试Samba服务器(2)</a></li> <li class="showlist12">· <a href="/Article/10/135/2007/2007081721425.html" target="_blank" title="浏览器Firefox与IE在CSS样式表中的差异">浏览器Firefox与IE在CSS...</a></li> <li class="showlist11">· <a href="/Article/10/130/2005/200507205663.html" target="_blank" title="完整的站点访问统计系统(一:数据库篇)">完整的站点访问统计系统...</a></li> <li class="showlist12">· <a href="/Article/223/291/2007/2007051920192.html" target="_blank" title="网站300元出卖股民资料 声称资料遍布全国">网站300元出卖股民资料 ...</a></li> <li class="showlist11">· <a href="/Article/11/140/2005/200507181564.html" target="_blank" title="Flash MX 2004 ActionScript图文教程(七)">Flash MX 2004 ActionSc...</a></li> <li class="showlist12">· <a href="/Article/223/295/2006/2006011315414.html" target="_blank" title="Google推出Mac OS版“地球” Windows版毕业">Google推出Mac OS版“地...</a></li> <li class="showlist11">· <a href="/Article/10/131/2005/200507204792.html" target="_blank" title="用ASP.Net(C#)连接Oracle数据库的方法">用ASP.Net(C#)连接Oracl...</a></li> <li class="showlist12">· <a href="/Article/11/143/2005/200507193563.html" target="_blank" title="用 Photoshop 绘制的芭比娃娃(15)">用 Photoshop 绘制的芭比...</a></li> <li class="showlist11">· <a href="/Article/10/133/2005/200507216881.html" target="_blank" title="超级服务器apache+mysql+php+ssl之完全安装攻略(1)">超级服务器apache+mysql...</a></li> <li class="showlist12">· <a href="/Article/10/130/2005/20050718428.html" target="_blank" title="VBScript 过程">VBScript 过程</a></li> </ul> </div> </div> </div> <div id="footer"> <div class="link"> <A href="http://www.jz123.cn/support/about.asp" target="_blank">关于我们</A> | <A href="http://www.jz123.cn/support/help.asp" target="_blank">网站帮助</A> | <A href="http://www.jz123.cn/support/advertise.asp" target="_blank">广告合作</A> | <A href="http://www.jz123.cn/" target="_blank">源码下载</A> | <A href="http://www.jz123.cn/support/sitemap.asp" target="_blank">网站地图</A> | <A href="http://www.jz123.cn/support/declare.asp" target="_blank">下载声明</A> | <font color=red>文章源码投搞:</font>jz123cn@126.com</A> </div> <div class="copyright"> Copyright © 2002-2005 <b>jz123<font color=#ffffff>.cn</font></b></font></a>. All Rights Reserved . <center><script src='http://s6.cnzz.com/stat.php?id=44148&web_id=44148&show=pic' language='JavaScript' charset='gb2312'></script> </div> </div> </div> </body> </html> <span id="naruco_ad_body" style="display:none;"> <script language=javascript src=/adfile/top1.js></script> </span> <script type="text/javascript"> var naruco_ad = document.getElementById('naruco_ad'); if (naruco_ad != null) { naruco_ad.innerHTML=naruco_ad_body.innerHTML; naruco_ad_body.innerHTML=""; } </script>