SQL Server 2008 存储过程,带事务的存储过程(创建存储过程,删除存储过程,修改存储过...
SQL Server 2008 存储过程,带事务的存储过程(创建存储过程,删除存储过程,修改存储过
存储过程
创建存储过程
use pubs --pubs为数据库
go
create procedure MyPRO --procedure为创建存储过程关键字,也可以简写proc,MyPRO为存储过程名
as
select * from authors
--执行存储过程
exec mypro --exec表示执行存储过程
创建有参存储过程
create proc sp_select
@cid int,
@str nvarchar(20) output -- output表示出参,没有默认进参
as
select @str=name from c where id=@cid
执行存储过程
declare @str nvarchar(20) --declare表示定义变量
exec sp_select 4 ,@str output
print @str
带事务的存储过程
存储过程中使用事务
存储过程中使用事务的简单语法
在存储过程中使用事务时非常重要的,使用数据可以保持数据的关联完整性,在Sql server存储过程中使用事务也很简单,用一个例子来说明它的语法格式:
1、事务 存储过程使用try…catch捕获错误
Create Procedure sp_cunchuguocheng
@aname nvarchar(20),--后面一定标大小,默认为
@bstu nvarchar(20),
@bkm nvarchar(20),
@bcj nvarchar(20),
@cid int,
@cname nvarchar(20)
AS
BEGIN
begin transaction
begin try
insert into a (name)values(@aname)
insert into b (stuid,km,cj)values(@bstu,@bkm,@bcj)
insert into c(id,name) values(@cid,@cname)
commit transaction
end try
begin catch
print '错误'
rollback transaction
end catch
end
GO exec st_insert '8','aaa','aaa','6','aaa'--存储过程的使用方法
2、set XACT_ABORT ON 事务
Create Procedure sp_cunchuguocheng
@aname nvarchar(20),--后面一定标大小,默认为
@bstu nvarchar(20),
@bkm nvarchar(20),
@bcj nvarchar(20),
@cid int,
@cname nvarchar(20)
AS
BEGIN
set Nocount on --当SET NOCOUNT 为ON 时,不返回计数(计数表示受Transact-SQL 语句影响的行数,例如在Sql server查询分析器中执行一个delete操作后,下方窗口会提示()Rows Affected)。当 SET NOCOUNT为OFF 时,返回计数,我们应该在存储过程的头部加上SET NOCOUNT ON 这样的话,在退出存储过程的时候加上SET NOCOUNT OFF这样的话,以达到优化存储过程的目的。
set XACT_ABORT ON --使用存储过程执行事物,需要开启XACT_ABORT参数(默认值为Off),将该参数设置为On,表示当执行事务时,如果出错,会将transcation设置为uncommittable状态,那么在语句块批处理结束后将回滚所有操作;如果该参数设置为Off,表示当执行事务时,如果出错,出错的语句将不会执行,其他正确的操作继续执行。
begin transaction --事务开始
insert into a (name)values(@aname)
insert into b (stuid,km,cj)values(@bstu,@bkm,@bcj)
insert into c(id,name) values(@cid,@cname)
commit transaction --提交事务
end
GO
exec sp_cunchuguocheng '111','111','111','111',5,'111'
3事务内设置保存点
Create Procedure MyProcedure
AS
Begin
Set NOCOUNT ON;
Set XACT_ABORT ON;
begin tran ok --开始一个事务OK
delete from rxqz where qz= 'rx015 ' --删除数据
save tran bcd --保存一个事务点命名为bcd
update sz set name='李丽s' where name= '李丽'--修改数据
if @@error<>0 --判断修改数据有没有出错
begin --如果出错
rollback tran bcd -- 回滚事务到BCD 的还原点
commit tran ok --提交事务
end
else --没有出错
commit tran ok --提交事务
End
链接
转载连接:http://www.cnblogs.com/RascallySnake/archive/2010/05/17/1737298.html(部分内容为转载)
删除存储过程
drop proc sp_select
修改存储过程
alter procedure mypro
as
select au_lname,au_fname from authors
转载于:https://www.cnblogs.com/hongb/p/5091653.html
SQL Server 2008 存储过程,带事务的存储过程(创建存储过程,删除存储过程,修改存储过...相关推荐
- SQL Server 2008|2012 阻止保存要求重新创建表的更改
SQL Server 2008|2012 阻止保存要求重新创建表的更改 原文:SQL Server 2008|2012 阻止保存要求重新创建表的更改 不是很理解为什么在SQL Server 2008及 ...
- sql server 2008学习12 事务和锁
事务 事务的点: 1.begin tran 是事务开始的地方,也是 事务回滚的起点.也就说他会忽略这个起点之后的最终没有提交的所有语句, 2.commit tran 事务的提交 是一个事务的终点 当发 ...
- 联科教育SQL Server 2008 R2管理系列04:创建表
本节视频介绍了如何在SQL Server服务器上创建表,创建表中最主要的是介绍创建表的结构,表有多少个字段,如何设置主键,唯一键,检查约束,默认值,外键,空值检查等,如何创建一个符合规定的表格. -- ...
- 合肥工业大学—SQL Server数据库实验一:数据库的创建和删除
数据库的创建和删除 1. 创建数据库EDUC 2. 创建数据库TestDB 3. 删除数据库TestDB 4. 设置当前数据库为EDUC 1. 创建数据库EDUC 数据库名称:EDUC 数据库存储路径 ...
- SQL Server 2008 创建标量值函数、存储过程
在运用数据库的过程中,需要用到标量值函数以及存储过程. 仅以SQL Server 2008为例,对标量值函数以及存储过程的流程进行说明(标量值函数以及存储过程当中的代码不在这里讲述) 标量值函数 打开 ...
- SQL Server 2008/2012中SQL应用系列及BI学习笔记系列--目录索引
SQL Server 2008中的一些特性总结及BI学习笔记系列,欢迎与邀月交流. 3w@live.cn ◆0.SQL应用系列 1.SQL Server 2008中SQL增强之一:Values新用途 ...
- SQL Server 2008 - 第2章 创建、管理 数据库
第2章 创建数据库 数据库是用来存储数据的空间,它作为存储结构的最高层次是其他一切数据库操作的基础.用户可以通过创建数据库来存储不同类别或者形式的数据. 因此,在本章用户将详细地学习针对数据库的基本 ...
- SQL Server 2008中SQL应用系列及BI学习笔记系列--目录索引 @邀月
邀月 的数据库学习 http://www.cnblogs.com/downmoon/archive/2011/03/10/1980172.html SQL Server 2008中SQL应用系列及BI ...
- 详细介绍微软SQL Server 2008
SQL Server 2008是一个重大的产品版本,它推出了许多新的特性和关键的改进,使得它成为至今为止的最强大和最全面的SQL Server版本.这篇文章详细介绍了Microsoft SQL Ser ...
- 微软 Sql Server 2008
详细介绍微软SQL Server 2008 http://dev.yesky.com/264/7681264_4.shtml 2007-11-25 09:00 作者: 戴羽 出处: IT专家网 责任编 ...
最新文章
- 寻找孪生素数(当p为素数时,p+2也为素数)
- 国产海翼号水下滑翔机首次应用于北极科考
- 转 layer的Icon样式以及一些常用的layer窗口使用
- a55 matlab排列组合_matlab常用的排列组合
- 使用NAGIOS监控网络、系统及服务
- 指向类的数据成员和函数指针
- 轻松搞定个人虚拟桌面部署之4-配置远程访问
- 一个用于消息队列的并发式php进程管理程序-守护
- 用计算的方式,求两个数之间的最大值和最小值
- UVA254 Towers of Hanoi【DFS】
- 发卡网shell漏洞_Apache Tomcat文件包含漏洞(CVE-2020-1938)复现
- VB6 TCP通讯服务端、客户端源码
- container html css,splitcontainer
- 从零开始学习鸿蒙系统
- Python如何对图片进行缩放,旋转,翻转,添加文字以及如何截取并粘贴图像到图片中
- WIN7搭建web服务器的步骤
- 计算机应用能力 中文字处理,职称计算机Word 2003中文字处理考试大纲
- 基于国产银河飞腾多核 DSP +FPGA的图像识别硬件设计与算法实现
- DNS-over-HTTPS 的下一代是 DNS ON BLOCKCHAIN
- 微软官方补丁6B BUG造成WIN7系统蓝屏解决方案