转至繁体中文版     | 网站首页 | 文章中心 | 下载中心 | 图片中心 | 笑话频道 | 教程频道 | 会员中心 | 雁过留声 | 
最新公告:     "MinTao学以致用网"欢迎您的光临,你的支持便是我们的动力,欢迎广大网友和各界人士亲临指导,你们的一个小小的建议便是我们发展的开路石!  [MinTao  2007年9月5日]        
您现在的位置: MinTao学以致用网 >> 文章中心 >> 电子课堂 >> 数据库 >> Sql Server >> 文章正文
专题栏目
更多内容
最新推荐 更多内容
相关文章
通过HTTP访问SQL Server
SQL Server的存储过程调
SQL Server安全性简介
SQL 语法参考手册
MS SQL Sever 7.0 存储引
SQL SERVER和SYBASE
SQL Server 7.0数据库的
VB应用程序访问SQL Serv
将DBF数据库转换成SQL S
拷贝的SQL Server 7数据
更多内容
SQL Server中使用外部命令执行sql脚本         
SQL Server中使用外部命令执行sql脚本
作者:davidullua 文章来源:不详 点击数: 更新时间:2007-11-14 12:53:54

Author:David Euler
Date: 2004/09/28
Email:de_euler-david@yahoo.com.cn

有任何问题,请与我联系:)

   有时候我们需要多次运行一个文件夹下所有的sql脚本(可能时txt或者sql等文本文件)来更新Schema,文件多的时候需要多次执行,那么可以使用多条语句来执行sql脚本。 --下面的查询语句在SQL Query中运行,将执行d:\vss下面的指定sql脚本,这些脚本的后缀都是txt exec master..xp_cmdshell ''''isql  -U  sa  -P  123  -i  d:\vss\MSSchema.txt ''''
exec master..xp_cmdshell ''''isql  -U  sa  -P  123  -i  d:\vss\MSSchema_030311.txt ''''
exec master..xp_cmdshell ''''isql  -U  sa  -P  123  -i  d:\vss\MSSchema_030416.txt''''
exec master..xp_cmdshell ''''isql  -U  sa  -P  123  -i  d:\vss\MSSchema_030417.txt''''
exec master..xp_cmdshell ''''isql  -U  sa  -P  123  -i  d:\vss\MSSchema_030513.txt''''
exec master..xp_cmdshell ''''isql  -U  sa  -P  123  -i  d:\vss\MSSchema_030613.txt''''
exec master..xp_cmdshell ''''isql  -U  sa  -P  123  -i  d:\vss\MSSchema_031010.txt''''
exec master..xp_cmdshell ''''isql  -U  sa  -P  123  -i  d:\vss\MSSchema_050810.txt''''
  exec master..xp_cmdshell ''''isql  -U  sa  -P  123  -i  d:\vss\TaxInvoice.sql''''   当然,我们完全可以不使用存储过程,而只是在一个批处理文件updateschema.cmd中执行这些命令,下面是updateschema.cmd的内容: ;下面的命令将执行d:\vss下面的指定sql脚本: isql  -U  sa  -P  123  -i  d:\vss\MSSchema.txt 
isql  -U  sa  -P  123  -i  d:\vss\MSSchema_030311.txt
isql  -U  sa  -P  123  -i  d:\vss\MSSchema_030416.txt
isql  -U  sa  -P  123  -i  d:\vss\MSSchema_030417.txt
isql  -U  sa  -P  123  -i  d:\vss\MSSchema_030513.txt
isql  -U  sa  -P  123  -i  d:\vss\MSSchema_030613.txt
isql  -U  sa  -P  123  -i  d:\vss\MSSchema_031010.txt
isql  -U  sa  -P  123  -i  d:\vss\MSSchema_050810.txt
  注: 1.exec语句用来执行存储过程,xp_cmdshell是master数据库中的一个扩展存储过程,可以用来执行系统命令的字符串   比如exec master..xp_cmdshell ''''dir *.exe''''查看当前目录下所有的exe文件。    2.isql是sql server的一个实用工具,可以理解程一个外部程序,如果sql使用的默认安装,可以在C:\Program Files\Microsoft SQL Server\80\Tools\Binn目录中找到这个isql.exe文件,isql可以用来执行Transact-SQL语句,存储过程,以及脚本文件, 参数-U用来指定登陆服务器的用户名,-P用来指定密码, 参数-i用来指定读取执行的脚本文件, 参数-o用来指定保存输出结果的文件名。   3.其他Oracle,DB2,MySQL,PostgreSQL等几个常用数据库中也有相应的工具也可以实现类似的功能。

文章录入:mintao    责任编辑:mintao 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007 MinTao学以致用网(www.mintao.net) Inc All Rights Reserved.
    QQ:543098146有事请Q我! QQ:261561092有事请Q我 QQ:179647303有事请Q我 MSN:min906@126.com
    站长:MinTao 信息产业部ICP备案号:鄂ICP备07500065号

    学以致用是我们学习者的至高境界和不懈追求,[MinTao学以致用网]与大家共同学习,共同进步……
    信息产业部备案
    *鄂ICP备07500065号