sqlserver数据库触发器和存储过程案例学习
--创建表
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数据库触发器和存储过程案例学习的更多相关文章
- sqlserver数据库触发器调用外部exe
sqlserver数据库触发器调用外部exe,同事可以选择参入参数! sqlserver使用 master..xp_cmdshell 进行外部exe的执行. 使用master..xp_cmdshell ...
- 连接sqlServer数据库&jpa调用存储过程Java获取存储过程返回的多个结果集JAVA调用sqlserver存储过程的实现(返回多个结果集的实现)jdbc多结果集(getMoreResults)
存储过程: BEGIN select * from teacher; SELECT * FROM student; END public Object GetMyBOProjectProductLis ...
- 查询sqlserver数据库视图、存储过程等包含特定的字符串
SELECT A.name , B.definition FROM SYS.objects A INNER JOIN sys.sql_modules B ON A.object_id = B.obje ...
- PostgreSQL 优势,MySQL 数据库自身的特性并不十分丰富,触发器和存储过程的支持较弱,Greenplum、AWS 的 Redshift 等都是基于 PostgreSQL 开发的
PostgreSQL 优势 2016-10-20 21:36 686人阅读 评论(0) 收藏 举报 分类: MYSQL数据库(5) PostgreSQL 是一个自由的对象-关系数据库服务器(数据库 ...
- [MySQL数据库之Navicat.pymysql模块、视图、触发器、存储过程、函数、流程控制]
[MySQL数据库之Navicat.pymysql模块.视图.触发器.存储过程.函数.流程控制] Navicat Navicat是一套快速.可靠并价格相当便宜的数据库管理工具,专为简化数据库的管理及降 ...
- JAVA使用JDBC技术操作SqlServer数据库执行存储过程
Java使用JDBC技术操作SqlServer数据库执行存储过程: 1.新建SQLSERVER数据库:java_conn_test 2.新建表:tb_User 3.分别新建三个存储过程: 1>带 ...
- 查询Sqlserver数据库死锁的一个存储过程(转)
使用sqlserver作为数据库的应用系统,都避免不了有时候会产生死锁, 死锁出现以后,维护人员或者开发人员大多只会通过sp_who来查找死锁的进程,然后用sp_kill杀掉.利用sp_who ...
- Sqlserver数据库 通过表触发器 实时通知应用程序
/* Sqlserver数据库开始相关服务 以下示例显示了如何查看 OLE Automation Procedures 的当前设置.0未启用 */ EXEC sp_configure 'show ad ...
- MySQL 之 视图、触发器、存储过程、函数、事物与数据库锁
浏览目录: 1.视图 2.触发器 3.存储过程 4.函数 5.事物 6.数据库锁 7.数据库备份 1.视图 视图:是一个虚拟表,其内容由查询定义.同真实的表一样,视图包含一系列带有名称的列和行数据 视 ...
随机推荐
- URAL 2067 Friends and Berries (推理,数学)
题意:给定 n 个人,每个人两个值s, r,要满足,p(v, u) = sqrt((sv − su)^2 + (rv − ru)^2), p(v,u,w) = (p(v,u) + p(v,w) + p ...
- HDU 5776 sum (前缀和)
题意:给定 n 个数,和 m,问你是不是存在连续的数和是m的倍数. 析:考虑前缀和,如果有两个前缀和取模m相等,那么就是相等的,一定要注意,如果取模为0,就是真的,不要忘记了,我当时就没记得.... ...
- hdoj 5389 Zero Escape
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5389 大体题意是:有两个门A和B,还有一群人,每个人都有一个数字, 疯了一样的T..比赛的时候十连T也 ...
- input value的值不可改变
同样是东钿微信服务平台,使用积分的问题,原来的版本是,默认用户不使用积分,也就没有给input赋值,后面华总说默认让用户使用积分,于是我就信誓旦旦把从后台得到用户可使用的积分赋在input上,后来,用 ...
- android UI开源库
. ActionBarSherlock ActionBarSherlock是一个独立的Android设计库,可以让Android 2.x的系统也能使用ActionBar.此 外,ActionBarSh ...
- Fragment进阶
fragment之间的通信,fragment和Activity生命周期之间的关系 通过上一篇浅显的学习了一下,怎么在Activity中添加fragment.在介绍fragment之间的通信之前,我们来 ...
- JavaScript 跨域:谈谈跨域之 JSONP
在 Web 开发中,后台开发人员应该会通常遇到这个问题:跨域,而使用 JSONP 就是其中解决办法之一,当然,还有其它解决方法,比如:window.name.window.postMessage.CO ...
- 如何在使用了updatepanel后弹出提示信息
转载:http://www.cnblogs.com/brusehht/archive/2009/03/19/1416802.html 常情况下,我们在使用ajax利用updatepanel实现页面局部 ...
- vim复制多行<转>
比如我要复制从第1行到第5行的数据,复制到第9行 光标移到第5行任意位置,输入ma光标移到第1行任意位置,输入y'a(这一定要打这个“'”单引号,否则就进入“INSERT”状态了光标移到需要复制的行, ...
- boost::token_compress_on
对于场景:string s = "123456",用"3","4"切分,默认情况下(boost::token_compress_off),切 ...