编写数据库脚本
2018-09-06 11:25
作者:AndrewClinick
我在“IfItMoves,ScriptIt”(英文)这篇文章中曾谈到,如何使用“WindowsScriptHost(WSH)”(Windows脚本主机)管理Windows和Windows中的应用程序。文中的大多数示例都是基于管理Windows操作系统自身的,并不基于在该操作系统下运行的应用程序。为迎接新千年,我想我应该谈谈,如何在众多显露可脚本化接口的应用程序中使用脚本。这次只涉及“SQLServer”。在以后的几个月中,我将着重谈Exchange、Office和“系统管理服务器”。
您可以通过使用“分布式管理对象”、“数据转换服务”和新的“SQLServerxml(标准化越来越近了)”实现,将脚本用于“SQLServer”。
许多人都能够通过“ActiveDataObject(ADO)”和“ActiveServerPage(ASP)”技术访问数据库了。ADO在帮助您查询和更新数据库方面做了大量的工作—但在备份(Y2K问题带给我们的警惕)或是数据库之间的传输数据方面,其表现又如何呢?而这时就非涉及到xml(标准化越来越近了)不可了。
在此,我将告诉您如何通过使用ADO的伴随技术-特别是“分布式管理对象”、“数据转换服务”和新的“SQLServerxml(标准化越来越近了)”实现,将脚本用于“SQLServer”。
分布式管理对象
“分布式管理对象(DMO)”是一组COM对象,它将“SQLServer”数据库和复制管理封装在一起。这意味着您可以编写一个WSH脚本,将特定表中的所有数据都复制到用制表符分隔的文件中,这有助于大量数据的移动。我之所以选择这个示例,是因为它的代码编写起来简单,但DMO允许您获取“SQLServer”中的每个对象,使您能够编写出一些非常优秀而有意义的管理脚本。
DMO的关键是SQLDMO.SQLServer对象,它是基本的对象,它允许您连接到服务器并获取所有可用对象。在这种情况下,我将使用Database集合来选择数据库,然后从table集合访问要转储到文件的表。如果不提供数据库,将出现错误消息,并且脚本也就结束了。如果不提供表名,脚本将在数据库所有的表中循环,并导出非系统表。如果提供了数据库,它就导出该表。该示例虽然功能有限,但它为“SQLServer”提供了基于命令行的简单的导出实用程序,您可以以它为根据。
现在先看一段代码:
声明与sql谈话时使用的变量
DimoServerSQLServer对象
DimoDatabase要使用的目标数据库
DimoBCPBCP对象
DimnRows从bcp返回的行数
dimtable表对象
onerrorresumenext
第一个参数必须是数据库
ifWScript.Arguments(0)=then
WScript.Echo您没有提供要连接的数据库
WScript.Quit
endif
创建SQLDMO的实例
SetoServer=CreateObject(SQLDMO.SQLServer)
创建SQLDMOBulkcopy对象的实例
SetoBCP=CreateObject(SQLDMO.BulkCopy)
oServer.EnableBcp=True
登录到本地服务器
希望您已经更改了sa口令!!
连接到提供的数据库
SetoDatabase=oServer.Databases(Wscript.Arguments(0))
将分隔符设置为逗号
oBCP.ColumnDelimiter=vbComma