--创建表
create table zhuangzhan
(
name nvarchar(10),
code varchar(20)
);
--往表添加一列
alter table zhuangzhan add descition int;
--添加数据
select * from zhuangzhan
insert zhuangzhan values('王五','',10000);
insert zhuangzhan values('李四','',0); --给表创建触发器用于添加数据出发,不允许添加code相同的数据
alter trigger mytrigger on zhuangzhan
for insert
as
begin tran
if exists(select code from zhuangzhan group by code having count(code)=2)
begin
rollback tran
end
else
begin
commit tran
end
end
--测试
insert zhuangzhan values('王五','',1);
--移除存储过程
drop procedure oneTOother_proc
--创建存储过程
create proc myproc
(
--输入参数
@names nvarchar(20),
@code varchar(20),
@i int output --输出参数
)
as
declare @counts int
begin tran
select @counts=count(code) from zhuangzhan where code=@code
if @counts>=1
begin
set @i=1
rollback tran
end
else
begin
insert into zhuangzhan values(@names,@code,1)
commit tran
set @i=0
end
go
select * from zhuangzhan
declare @i int
exec myproc'EXO','',@i output print @i
--模拟银行转账,实现事物的用法
create proc oneTOother_proc
(
--输入参数
@outMoney int,--转帐金额
@formPeople varchar(20),--汇款人
@toPeopleCode varchar(20)--收款人账号
)
as
declare @yuE int --汇款人余额
declare @i int
declare @tocode int
declare @error int --定义错误号记录
select @yuE=descition from zhuangzhan where name=@formPeople
select @i=COUNT(name) from zhuangzhan where name=@formPeople
if(@yuE<@outMoney)
begin
print @formPeople+'账户余额不足'
return
end
else if(@i=0)
begin
print '汇款人'+@formPeople+'不存在'
return
end
else select @tocode=count(code) from zhuangzhan where code=@toPeopleCode
if(@tocode<1)
begin
print '收款人账号'+@toPeopleCode+'不存在'
return
end
else
begin tran --开始事物
begin
update zhuangzhan set descition=descition-@outMoney where name=@formPeople
set @error=@error+ @@ERROR
update zhuangzhan set descition=descition+@outMoney where code=@toPeopleCode
set @error=@error+ @@ERROR
end
if(@error>0)
begin
rollback transaction
end
else
begin
commit tran
print @error
print @formPeople+'给账号为:'+@toPeopleCode+'汇款'+cast(@outMoney as varchar(10))+'元'
end
go select * from zhuangzhan exec oneTOother_proc 500000,'王五',''

sqlserver数据库触发器和存储过程案例学习的更多相关文章

  1. sqlserver数据库触发器调用外部exe

    sqlserver数据库触发器调用外部exe,同事可以选择参入参数! sqlserver使用 master..xp_cmdshell 进行外部exe的执行. 使用master..xp_cmdshell ...

  2. 连接sqlServer数据库&jpa调用存储过程Java获取存储过程返回的多个结果集JAVA调用sqlserver存储过程的实现(返回多个结果集的实现)jdbc多结果集(getMoreResults)

    存储过程: BEGIN select * from teacher; SELECT * FROM student; END public Object GetMyBOProjectProductLis ...

  3. 查询sqlserver数据库视图、存储过程等包含特定的字符串

    SELECT A.name , B.definition FROM SYS.objects A INNER JOIN sys.sql_modules B ON A.object_id = B.obje ...

  4. PostgreSQL 优势,MySQL 数据库自身的特性并不十分丰富,触发器和存储过程的支持较弱,Greenplum、AWS 的 Redshift 等都是基于 PostgreSQL 开发的

    PostgreSQL 优势 2016-10-20 21:36 686人阅读 评论(0) 收藏 举报  分类: MYSQL数据库(5)  PostgreSQL 是一个自由的对象-关系数据库服务器(数据库 ...

  5. [MySQL数据库之Navicat.pymysql模块、视图、触发器、存储过程、函数、流程控制]

    [MySQL数据库之Navicat.pymysql模块.视图.触发器.存储过程.函数.流程控制] Navicat Navicat是一套快速.可靠并价格相当便宜的数据库管理工具,专为简化数据库的管理及降 ...

  6. JAVA使用JDBC技术操作SqlServer数据库执行存储过程

    Java使用JDBC技术操作SqlServer数据库执行存储过程: 1.新建SQLSERVER数据库:java_conn_test 2.新建表:tb_User 3.分别新建三个存储过程: 1>带 ...

  7. 查询Sqlserver数据库死锁的一个存储过程(转)

        使用sqlserver作为数据库的应用系统,都避免不了有时候会产生死锁, 死锁出现以后,维护人员或者开发人员大多只会通过sp_who来查找死锁的进程,然后用sp_kill杀掉.利用sp_who ...

  8. Sqlserver数据库 通过表触发器 实时通知应用程序

    /* Sqlserver数据库开始相关服务 以下示例显示了如何查看 OLE Automation Procedures 的当前设置.0未启用 */ EXEC sp_configure 'show ad ...

  9. MySQL 之 视图、触发器、存储过程、函数、事物与数据库锁

    浏览目录: 1.视图 2.触发器 3.存储过程 4.函数 5.事物 6.数据库锁 7.数据库备份 1.视图 视图:是一个虚拟表,其内容由查询定义.同真实的表一样,视图包含一系列带有名称的列和行数据 视 ...

随机推荐

  1. shutdown 和closesocket

    来,咱们彻底的来讨论一下这个shutdown   和closesocket 从 函数调用上来分析(msdn):一旦完成了套接字的连接,应当将套接字关闭,并且释放其套接字句柄所占用的所有资源.真正释放一 ...

  2. Java垃圾回收器

    一.Java垃圾回收器要负责完成以下3个任务: 1.分配内存 2.确保被引用对象的内存不被错误回收 3.回收不再被引用的对象的内存空间 二.垃圾回收是一个复杂而又耗时的操作.如果JVM花费过多的时间在 ...

  3. SQLServer2005 提示 '其他会话正在使用事务的上下文'

    MSDN上看了一下说是sql server 2005不支持在分布式事务处理中存在指向本地的链接服务器(环回链接服务器) 这个是官方的回答 个人认为,应该是在事务中,使用了链接服务器访问进行跨库访问引起 ...

  4. android 简易定时器

    定时器 1.在android 应用开发当中,很多时候都要用到定时器,而要实现定时器更多的时候要用到两个类:Timer,和TimerTask 2.API对Timer的解释是:

  5. MRI中T1和T2的含义与区分[转]

    A. MRI名词解释   T1加权像.T2加权像为磁共振检查中报告中常提到的术语,很多非专业人士不明白是什么意思,要想认识何为T1加权像.T2加权像,请先了解几个基本概念:   1.磁共振(maget ...

  6. (1)html开头解说与案例演示

    看完后也可以参考http://www.cnblogs.com/csxiaoyu/p/5228889.html http://www.cnblogs.com/zfc2201/p/5429252.html ...

  7. Introduction into ISO 27145 WWH-OBD

    全球统一的重型发动机的车载诊断系统(WWH-OBD) ISO/PAS 27145 is intended to become the single communication standard for ...

  8. IE6中奇数宽高的BUG

    一个外部的相对定位div,内部一个绝对定位的div(right:0), 如图: 可是在IE6下查看,却变成了right:1px的效果了: IE6还有奇数宽高的bug,解决方案就是将外部相对定位的div ...

  9. C#创建windows服务搭配定时器Timer使用实例(用代码做,截图版)

       功能说明:C#创建一个windows服务,服务启动时D:\mcWindowsService.txt写入数据,服务运行期间每隔两秒写入当前时间. 原理这些就不说了,三语两语说不清楚,直接贴一个实例 ...

  10. Gridview全选

    1.js代码 <script language="javascript" type="text/javascript">               ...