--创建表
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. [Mac]Mac Xcode 删除已经下载好的模拟器版本

    Delete simulator refences for xCode: Delete the particular simulator runtime references (*.simruntim ...

  2. typedef block

    给同一种类型的block定义一个别名 typedef int (^MyBlock) (int , int); int main(int argc, const char * argv[]) { @au ...

  3. Spring+jpa+access

    ========访问数据库的属于文件============ driver=com.hxtt.sql.access.AccessDriverurl=jdbc:access:/D:/eclipse/pr ...

  4. c++中的signal机制

    简介 signal是为了解决类之间通信的问题而出现的,更深入的原因是面向对象讲究封装,但是封装必然导致类之间沟通困难,但是使用接口的方式又太重量级--需要写很多代码,而且会导致接口爆炸 比如你需要把一 ...

  5. 无责任Windows Azure SDK .NET开发入门篇二[使用Azure AD 进行身份验证]

    二.使用Azure AD进行身份验证 之所以将Azure AD 作为开始,是应为基本上我们所有应用都需要进行安全管理.Azure Active Directory (Azure AD) 通过以下方式简 ...

  6. jquery 禁止页面滚动-移动端

    禁止 window.ontouchmove=function(e){        e.preventDefault && e.preventDefault();        e.r ...

  7. jquery 显示“加载状态 结束”

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. oracle存储过程实例

    oracle存储过程实例 分类: 数据(仓)库及处理 2010-05-03 17:15 1055人阅读 评论(2)收藏 举报 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的P ...

  9. Android Checkbox Example

    1. Custom String 打开 “res/values/strings.xml” 文件, File : res/values/strings.xml <?xml version=&quo ...

  10. [Express] Level 2: Middleware -- 2

    Logging Middleware Help finish the following middleware code in the logger.js file: On the response  ...