sql批处理语句
㈠ 如果通过批处理执行sql server语句
楼主你好,首先,我鄙视下楼上的二位。
您的意思是,把查询语句都写在一个文本文件里,然后双击一个bat文件,就自动执行文本文件里的语句对吧,OK,看下面步骤:
1.新增一个批处理文件:如a.bat
2.新增一个SQL脚本文件:如a.sql
3.a.bat中输入:
isql -U 用户名 -P 密码 -i c:\a.sql
同样在bat文件中,输入上面一行,在a.sql输入脚本.
如:
use 数据库名
go
select * from 表名
go
注意:如果您是SQL 2005的,请把bat文件中的isql改成osql即可。
祝您成功!
㈡ SQL server中的事务与批处理语句有什么区别
ACID,是指在可靠数据库管理系统(DBMS)中,事务(transaction)所应该具有的四个特性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability).这是可靠数据库所应具备的几个特性.下面针对这几个特性进行逐个讲解.
原子性意味着数据库中的事务执行是作为原子。即不可再分,整个语句要么执行,要么不执行。 在SQL SERVER中,每一个单独的语句都可以看作是默认包含在一个事务之中:
对于用户来说,要用事务实现的自定义原子性往往是和业务相关的,比如银行转账,从A账户减去100,在B账户增加100,如果这两个语句不能保证原子性的话,比如从A账户减去100后,服务器断电,而在B账户中却没有增加100.虽然这种情况会让银行很开心,但作为开发人员的你可不希望这种结果.而默认事务中,即使出错了也不会整个事务进行回滚。而是失败的语句抛出异常,而正确的语句成功执行。这样会破坏原子性。所以SQL SERVER给予了一些选项来保证事务的原子性.
数据库中实现事务性有三种方法,这里只介绍前两种方法:
1. 在事务语句最前面加上set xact_abort on
如:
create procere SP_Trans_Account @UserID int,@DestID int,@imoney bigint
as
begin
set xact_abort on
begin tran
update TUserInfo set WalletMoney=WalletMoney+@imoney where UserID=@DestID
update TUserInfo set WalletMoney=WalletMoney-@imoney where UserID=@UserID
commit tran
end当xact_abort 选项为on 时,SQL Server在遇到错误时会终止执行并rollback 整个事务。
2. 在每个单独的DML语句执行后,立即判断执行状态,并做相应处理。
create procere SP_Trans_Account @UserID int,@DestID int,@imoney bigint
begin tran
update TUserInfo set WalletMoney=WalletMoney+@imoney where UserID=@DestID
update TUserInfo set WalletMoney=WalletMoney-@imoney where UserID=@UserID
if @@error<>0 --如果不为零,表示事务发生错误,则回滚事务
begin
rollback tran
end
else
begin
commit tran --提交事务
end
原文链接:网页链接
㈢ SQL批处理语句是什么
不是的,这个在这里一两句讲不清楚的,您需要专门学习一下P/L SQL的知识,可以说是一种依托于数据库实现的脚本语言,最大的用途就是写数据库函数和存储过程。
㈣ 在SQL数据库中,什么叫批处理
批处理就是单个或多个T—SQL语句的集合,由应用程序一次性发送给SQL
Server解析执行处理内的所有语句指令。
㈤ 如何用批处理写一条SQL的语句
mssql 中isql 工具支持批处理,把sql语句写到文件中,然后建一个批处理语句,isql -Sserver -Usa -Ppass -c -d databasename -i执行文件名 -o 执行结果log
㈥ 在SQL数据库中,什么叫批处理
批处理就是把一批SQL脚本按顺序执行!
通常用GO来分割不同的批处理!
㈦ sql中的批处理
SQL批处理:指包含一条或多条T - SQL语句的语句组,这组语句从应用程序一次性地发送到SQL server服务器执行。编批处理程序时,最好能够以分号结束相关语句。虽然这不数据库强制求,但笔还强烈建议如此处理。方面这有利于提批处理程序读性。批处理程序往往完成些比较复杂成套功能,而每条语句则完成项独立功能。此有时个比较复杂些批处理程序其往往有百行容。此时提其读性,最好能够利分号进行语句语句间分隔。二未版本性。其实SQL Server数据库设计时候,开始这方面就关不严。现部分标准程序编器都实现类似强制控制。根据宪梓微软官方提供资料看,以SQL Server数据库版本,这个规则能成个强执行规则,即必须每条语句面利分号进行分隔。此能够跟续SQL Server数据库版本进行,最好从现开始就采分号分隔批处理程序每条语句。
㈧ DELPHI中SQL语句的批处理是怎么写的
没有用过批处理,只是一条一条执行sql,完毕就可以
用事务,不用Tadoquery等组件:
procere TForm1.Button1Click(Sender: TObject);
begin
adoconnection1.begintrans;
try
adoconnection1.execute(update 语句);
如果还有insert 语句则:
adoconnection1.execute(update 语句);直到所有update语句完成.
adoconnection1.committrans;
except
adoconnection1.rollbacktrans;
end;
end;
说的更通俗一点就是
SQL Server支持一次执行多条SQL语句的,直接放在SQL.Text就可以
比如:
with Query1 do
begin
Close;
SQL.Clear;
SQL.Add('Select * From Table1');
SQL.Add('Update Table2 Set Field1=1');
Open;
end;
两条语句都会被执行
用事务处理,如果执行时出现异常,可以adoconnection1.rollbacktrans撤销。
adoconnection1.begintrans;
//UPDATE语句1
//UPDATE语句2
//UPDATE语句3
。。。。。。
adoconnection1.rollbacktrans;
㈨ SQL批处理语句解释
select * from reader
--查询reader表所有数据
alter table reader--修改表 reader
add rscore int--添加列 rscore 类型为 int
update reader set rscore=20 where rid=1
update reader set rscore=510 where rid=2
update reader set rscore=4679 where rid=3
update reader set rscore=2200 where rid=4
---设置 每行rscore 的值
case... when... then
select *,[level]=case
when rscore<=100 then '一级'
when rscore<=500 then '二级'
when rscore<=1000 then '三级'
when rscore<=2000 then '四级'
when rscore<=4000 then '五级'
else '顶级'
end
from reader
--以上查询所有数据值 并增加一列level 根据rscore的值大小进行处理
--添加读者类型这一列
alter table reader
add rtype int
--显示读者类型信息,用中文显示
select *,读者类型=case rtype when 1 then '普通读者'
when 2 then '会员读者'
when 3 then '黄金读者'
end,
等级=case when rscore<=100 then '一级'
when rscore<=500 then '二级'
when rscore<=1000 then '三级'
when rscore<=2000 then '四级'
when rscore<=4000 then '五级'
else '顶级'
end
from reader
-- 以上同理