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.视图 视图:是一个虚拟表,其内容由查询定义.同真实的表一样,视图包含一系列带有名称的列和行数据 视 ...
随机推荐
- js get 传参 汉字 乱码问题
js encodeURI(encodeURI(searchWord)) java URLDecoder.decode(searchWord,"utf-8")
- sqlserver:同一数据库内负责表结构。
select * into 新表 from 旧表 where 1=2; ## where 表示要携带的数据,随便写个恒不等式就可以只复制表结构不携带数据.
- maven仓库介绍
maven仓库介绍 http://juvenshun.iteye.com/blog/359256
- uva129 - Krypton Factor 7.4.3 困难的串
7.4.3困难的串 学习点:dfs加入返回值,递归搜索过程中如果有一个成功,就直接退出 //7.4.3 困难的串 #include<cstdio> #include<cstrin ...
- 记录一下centos安装httpd+php+mysql的过程
1.安装apache httpd 这个貌似安装完centos后自带了,如果没有,也可以用yum安装 yum -y install httpd 2.安装php yum -y install php ph ...
- JavaScript创建Map对象(转)
JavaScript 里面本身没有map对象,用JavaScript的Array来实现Map的数据结构. /* * MAP对象,实现MAP功能 * * 接口: * size() 获取MAP元素 ...
- scenes & segues within storyboards
Scenes Scenes in a storyboard represent content shown within one screen in your application. A scene ...
- Codeforces Round #188 (Div. 2) A. Even Odds 水题
A. Even Odds Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/318/problem/ ...
- iOS开发——网络编程OC篇&使用WebView构建HyBird应用
使用WebView构建HyBird应用 HyBird是一种本地技术与Web相结合,能过实现跨平台的移动应用开发,最常用的一个框架:PhoneGap 一:首先,写好html代码 <!DOCTYPE ...
- iOS开发——UI篇Swift篇&UISlider
UISlider override func viewDidLoad() { super.viewDidLoad() titleLabel.text = titleString // Do any a ...