批量执行sql脚本
使用SQLCMD在SQLServer上执行多个脚本
第一步:先创建一个在C盘下的文件夹:C:\Scripts。然后把脚本存放到这个文件夹中:
脚本1:CREATE_DB.sql
/* SCRIPT: CREATE_DB.sql */
/* 创建TestDB数据库 */
-- This is the main caller for each script
SET NOCOUNT ON
GO
PRINT '开始创建TestDB数据库'
IF EXISTS (SELECT 1 FROM SYS.DATABASES WHERE NAME = 'TestDB')
DROP DATABASE TestDB
GO
CREATE DATABASE TestDB
GO
:On Error exit
:r c:\Scripts\CREATE_TABLES.sql
:r c:\Scripts\TABLE_INSERTS.sql
:r c:\Scripts\CREATE_INDEXES.sql
:r c:\Scripts\CREATE_PROCEDURES.sql
PRINT '创建完毕'
GO
2. 阿里云的数据库服务器如何批量执行本地的sql文件
如果数据库可以远程连接,直接使用工具连接就可以导入了如果不支持,有两种情况:一般虚拟机上都会提供数据库管理的工具,使用工具就可以。如果不提供,可以在JSP页面中使用JDBC,连接好数据库以后,可以使用FileInputStream将文件读取到内存中,然后在连接好的数据库执行读取的语句就可以了
3. 请教高手:DB2 SQL脚本批量执行如何保存日志问题
可以在命令编辑器或者Windows 的DB2 命令窗口或者 linux 的shell 中执行SQL 脚本。在windows 的DB2 命令窗口或者 linux 的shell 中执行SQL语句,可以使用下面的命令执行script1.sql脚本:
db2 -t -v -f script1.sql -z script1.log
或者:
db2 –tvf script1.sql –z script1.log
在上面的命令中,
-t 表示语句使用默认的语句终结符——分号;
-v 表示使用冗长模式,这样 DB2 会显示每一条正在执行命令的信息;
-f 表示其后就是脚本文件;
-z 表示其后的信息记录文件用于记录屏幕的输出,方便以后的分析(这是可选的,但我们建议使用该选项)。
当使用了-t选项而没有标明语句终结符,则分号(;)会默认为语句的终结符。有时可能会出现使用另外的终结符的情况,例如用SQL PL 编写的的脚本使用其它的符号而不是默认的分号,因为分号在SQL PL 是用于定义数据库对象过程中的语句结束。
4. 用批处理执行SQL文件的脚本应该怎么写
步骤:(1) 创建一个批处理文件:打开记事本,创建数据库连接信息(例如,server name,username,password,databasename等)以及要执行的*.sql脚本名称。具体语法参考下文"osql 实用工具" 。 将文件的扩展名改为.bat 并保存。
示例1:指定待执行sql 文件的相对路径
osql -S admin\admin -U sa -P sa -d TestDB -i c:\test.sql
pause
示例2: 待执行文件与bat文件在同一个目录,指定相对路径
set localdir=%~dp0
osql -S (local) -U sa -P sa -d Test -i %localdir%\test1.sql
osql -S (local) -U sa -P sa -d Test -i %localdir%\test2.sql
osql -S (local) -U sa -P sa -d Test -i %localdir%\test3.sql
pause
(2) 创建需要执行的sql 脚本, test.sql,test2.sql 和test3.sql, 并放在步骤(1)示例1中指定的位置。本例为c:\ 根目录。如果用示例2,将待执行的sql和bat文件放在同一个目录下。
(3) 双击*.bat 文件并查看运行结果。
5. 如何批量执行某个文件夹下所有的 sql脚本
1,先把sql脚本名字全部取出来
2,追加到一个文本文件里名字 yy.sql,比如 xx1.sql 就写
@@xx1.sql
@@xx2.sql
3,在文件目录下新建一个bat文件内容如下
sqlplus user/pwd@sid @yy.sql >tt.log
4,双击bat文件运行,就可以批量执行
注意,每个sql脚本文件里面的最后一行必须有 /
6. 如何批量执行sql查找替换
在Linux里面,有一个比较好的工具sed,sed -i "s#A#B#g" filename,比如:sed -i "s#linux#windows#g" a.txt,这样可以把a.txt文件中所有的linux替换成windows,“#”可以换成其他的字符,可以根据实际情况来定。如果替换的内容来自文件,可以用脚本遍历文件的方式实现。例如:
旧地址文件:A.txt,需要处理的sql文件:mysql.sql,替换后的新内容:newtext
#/bin/bash
for line in `cat .A.txt`;
do
sed -i "s#$line#newtext#g" mysql.sql
done
当然,也可以指定替换行的范围(例如50行到100行),具体的请参考linux下sed命令的用法
7. ADOCommand怎样批量执行sql语句,该怎么解决
因为SQL脚本中的Go是单独成行的,所以比较好判断,另外脚本中最好不要含有注释语句,如果注释过长的话会换行,这样要多判断一次。
另外SQL脚本要是Ansi格式,不要生成Unicode的,否则不能正确运行。
C/C++code
void__fastcallTForm1::Button1Click(TObject*Sender)
{
TStringList*SQL=newTStringList;
SQL->LoadFromFile(ExtractFilePath(Application->ExeName)+
"SQLScript");
ADOCommand1->CommandText="";
for(inti=0;i<SQL->Count;i++)
{
//遇到GO语句,执行
if(SQL->Strings[i]=="GO")
ADOCommand1->Execute();
else
//清除注释
if(SQL->Strings[i].SubString(0,2)=="/*"||
SQL->Strings[i].SubString(SQL->Strings[i].Length()-2,2)=="*/")
{
}
else
//不是GO,不是注释,不为空,则是SQL的执行语句
if(SQL->Strings[i].Trim()!=""&&
SQL->Strings[i].Trim()!="")
ADOCommand1->CommandText+=
SQL->Strings[i]+"";
}
}
8. sql弄成一次性执行通过脚本
1、把一个个的sql语句都写在存储过程里面。
2、把一个个的sql语句都写在txt文件里面,然后运行就可以了。
9. 我有一堆sql文件需要运行 如何批量运行
可以使用批处理,调用 isql 执行 .sql文件。
1、 新建test.sql 文件。如图,代码执行删除 表a中id='1'的记录。
3、运行批处理test.bat即可执行,test.sql中的SQL语句。