·建站首页 ·钻石 ·繁體
您的位置: 中国建站之家 -> 网站开发设计 -> ASP教程 -> 编写数据库脚本

编写数据库脚本

作者:未知  来源:转载  发布时间:2005-7-20 11:38:54  发布人:acx


我在“If It Moves, &#115cript It”(英文)这篇文章中曾谈到,如何使用“Windows &#115cript 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 W&#115cript.Arguments(0)&nbsp;=&nbsp;""&nbsp;then<br/>W&#115cript.Echo&nbsp;"您没有提供要连接的数据库"<br/>W&#115cript.Quit<br/>end&nbsp;if<br/>'&nbsp;创建&nbsp;SQL&nbsp;DMO&nbsp;的实例<br/>Set&nbsp;oServer&nbsp;=&nbsp;CreateObject("SQLDMO.SQLServer")<br/>'&nbsp;创建&nbsp;SQL&nbsp;DMO&nbsp;Bulkcopy&nbsp;对象的实例<br/>Set&nbsp;oBCP&nbsp;=&nbsp;CreateObject("SQLDMO.BulkCopy")<br/>oServer.EnableBcp&nbsp;=&nbsp;True<br/>'&nbsp;登录到本地服务器<br/>'&nbsp;希望您已经更改了&nbsp;sa&nbsp;口令!!<br/>oServer.Connect&nbsp;".",&nbsp;"sa"&nbsp;<br/>'&nbsp;连接到提供的数据库<br/>Set&nbsp;oDatabase&nbsp;=&nbsp;oServer.Databases(W&#115cript.Arguments(0))<br/><br/>'&nbsp;将分隔符设置为逗号<br/>oBCP.ColumnDelimiter&nbsp;=&nbsp;vbComma<br/>'&nbsp;将文件类型设置为以逗号分隔<br/>oBCP.DataFileType&nbsp;=&nbsp;SQLDMODataFile_CommaDelimitedChar<br/>oBCP.ImportRowsPerBatch&nbsp;=&nbsp;1000<br/>oBCP.MaximumErrorsBeforeAbort&nbsp;=&nbsp;1<br/>BCP.RowDelimiter&nbsp;=&nbsp;vbCrLf<br/>oBCP.ServerBCPDataFileType&nbsp;=&nbsp;SQLDMOBCPDataFile_Char<br/>oBCP.UseExistingConnection&nbsp;=&nbsp;True<br/>'&nbsp;如果未提供表,则转储所有的表<br/>f&nbsp;w&#115cript.Arguments(1)&nbsp;=&nbsp;""&nbsp;then<br/>for&nbsp;each&nbsp;table&nbsp;in&nbsp;oDatabase.tables<br/>'&nbsp;确保该表不是系统表<br/>if&nbsp;table.systemobject&nbsp;=&nbsp;false&nbsp;then<br/>oBCP.DataFilePath&nbsp;=&nbsp;table.name&nbsp;&&nbsp;".csv"<br/>nRows&nbsp;=&nbsp;table.ExportData(oBCP)<br/>w&#115cript.Echo&nbsp;nRows&nbsp;&&nbsp;"&nbsp;rows&nbsp;exported&nbsp;from&nbsp;"&nbsp;&&nbsp;table.name<br/>end&nbsp;if<br/>next<br/>else<br/>'&nbsp;设置输出文件<br/>oBCP.DataFilePath&nbsp;=&nbsp;w&#115cript.Arguments(1)&nbsp;&&nbsp;".csv"&nbsp;<br/>nRows&nbsp;=&nbsp;oDatabase.Tables(w&#115cript.arguments(1)).ExportData(oBCP)<br/>w&#115cript.Echo&nbsp;nRows&nbsp;&&nbsp;"&nbsp;rows&nbsp;exported&nbsp;from&nbsp;"&nbsp;&&nbsp;w&#115cript.arguments(1)<br/>end&nbsp;if<br/>DMO&nbsp;的全部内容要比本文介绍的多得多,但我希望本文能给您一些感性认识:用某些简单的&nbsp;WSH&nbsp;脚本和&nbsp;DMO&nbsp;可以做些什么。您可以下载我的示例(英文)。有关&nbsp;DMO&nbsp;的详细信息,请访问&nbsp;http://msdn.microsoft.com/library/psdk/sql/9_dmoc01.htm(英文)。&nbsp;<br/><br/>数据转换服务<br/>导出到&nbsp;Comma&nbsp;Separated&nbsp;文件&nbsp;(CSV),可以作为将数据导出到&nbsp;SQL&nbsp;和从&nbsp;SQL&nbsp;导入的起点,但这不象是尖端科技(太过于&nbsp;20&nbsp;世纪了,您不觉得吗?)。“SQL&nbsp;Server&nbsp;7.0”以“数据转换服务&nbsp;(DTS)”的形式,提供了相当完善的导入和导出机制。幸运的是,脚本在“SQL&nbsp;Server”的这个新领域中仍有一席之地,因此,您可以用“Visual&nbsp;Basic(R)&nbsp;脚本编辑&nbsp;(VB&#115cript)”、“J&#115cript(R)”或“Perl”的技术来扩展&nbsp;DTS&nbsp;的能力。<br/><br/>DTS&nbsp;的设置非常简单,特别是在使用“SQL&nbsp;ServerEnterprise&nbsp;Manager”的时候。在默认情况下,“SQL&nbsp;Server”有一个定义的文件夹,可存储任何转换,而且“Enterprise&nbsp;Manager”提供了创建和编辑&nbsp;DTS&nbsp;程序包的大的图形用户界面&nbsp;(GUI)。在下面的示例中,我选择了已由&nbsp;sqlexport.wsf&nbsp;文件创建的&nbsp;employees.csv&nbsp;文件和“SQL&nbsp;Server”中的一个新表。DTA&nbsp;程序包将创建该表,加载到&nbsp;Text&nbsp;文件中,然后运行某个脚本,将数据转换到“SQL&nbsp;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&nbsp;程序包中的转换,使脚本在整个转换过程中保持运行状态。“SQL&nbsp;Enterprise&nbsp;Manager”提供的简单的脚本编辑器,有一个语法分析脚本按钮。在运行脚本之前,该按钮将警告您脚本中的错误。在转换过程中,该脚本使用&nbsp;VB&#115cript&nbsp;的&nbsp;Cint&nbsp;功能,将&nbsp;employeeid&nbsp;和&nbsp;deptid&nbsp;的输入转换为&nbsp;int,并将所有的电子邮件地址转换为小写字母。<br/><br/>'**********************************************************************<br/>'&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Visual&nbsp;Basic&nbsp;转换脚本<br/>'&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;把每个源列复制到<br/>'&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;目标列<br/>'***********************************************************************<br/>Function&nbsp;Main()<br/>DTSDestination("EmployeeID")&nbsp;=&nbsp;cint(DTSSource("Col001"))<br/>DTSDestination("FirstName")&nbsp;=&nbsp;DTSSource("Col002")<br/>DTSDestination("LastName")&nbsp;=&nbsp;DTSSource("Col003")<br/>DTSDestination("email")&nbsp;=&nbsp;lcase(DTSSource("Col004"))<br/>DTSDestination("extension")&nbsp;=&nbsp;DTSSource("Col005")<br/>DTSDestination("office")&nbsp;=&nbsp;DTSSource("Col006")<br/>DTSDestination("DeptID")&nbsp;=&nbsp;cint(DTSSource("Col007"))<br/>Main&nbsp;=&nbsp;DTSTransformStat_OK<br/>End&nbsp;Function<br/>用&nbsp;DTS,能够采用某些完善的导入/导出机制,并使您能够在转换的任何一步中使用脚本。重要的是,要注意脚本可能不是操作数据的最佳方式&nbsp;—&nbsp;尤其是您的数据集很大的话。如果您有大量数</p></div><p align="center"><b><font color="red">[1]</font>&nbsp;<a href="200507205777_2.html">[2]</a>&nbsp;&nbsp;<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> &nbsp;&nbsp;<script language=javascript src=/wz/wangzhai/wangzhai.js></script></p> </div> <div class="list_menu_b"> <div class="left"> <h2>热门阅读 &raquo;</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>相关阅读 &raquo;</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 &copy; 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>