SqlServer和Oracle中一些常用的sql语句8 触发器和事务
--创建和执行事后触发器
--更新仓库备份表中记录时自动创建数据表且插入三条记录
create trigger db_trigger1 on 仓库备份 for update
as
begin
if Exists(select * from sys.sysobjects where id=OBJECT_ID('db_tabletriuser'))
drop table db_tabletriuser
else
begin
create table db_tabletriuser(
userid int identity(1,1) primary key,
username varchar(50),
userpwd varchar(50)
)
insert into db_tabletriuser(username,userpwd) values('hy1','111')
insert into db_tabletriuser(username,userpwd) values('hy2','222')
insert into db_tabletriuser(username,userpwd) values('hy3','333')
end
end --test
update 仓库备份 set 面积=面积-100 where 仓库号='wh1'
----------------------------------------------------------- --删除功能触发器
--实现当删除职工表中的一条记录时,删除该职工所对应的订购单信息
Create trigger db_delete_trigger on 职工 for delete
as
begin
declare @t varchar(10)
select @t=职工号 from deleted
delete from 订购单 where 职工号=@t
end --test
delete from 职工 where 职工号 ='zg5'
------------------------------------------------------- --更新功能触发器
--实现更新仓库表中一条记录的仓库号时,把职工表中对应的仓库号也进行修改
create trigger db_update_trigger on 仓库 for update
as
begin
declare @old char(10)
declare @new char(10)
select @new=仓库号 from inserted
select @old=仓库号 from deleted
update 职工 set 仓库号=@new where 仓库号=@old
end --test
update 仓库 set 仓库号='modifywh2' where 仓库号='wh2'
------------------------------------------------------------ --嵌套触发器
--实现当删除仓库表中一个仓库信息时,同时删除该仓库中所有职工的信息
--同时触发删除该仓库所有职工的订购单信息
create trigger db_Text_trigger1 on 仓库 for delete
as
begin
declare @t varchar(10)
select @t=仓库号 from deleted
delete from 职工 where 仓库号=@t
end create trigger db_Text_trigger2 on 职工 for delete
as
begin
delete from 订购单 where 职工号 in (select 职工号 from deleted)
end --test
delete from 仓库 where 仓库号='wh1'
-------------------------------------------------------- --创建触发器实现在仓库备份表中插入,更新或删除记录时自动发送邮件
create trigger db_trigger2 on 仓库备份 for Insert,Update ,Delete
as
begin
execute xp_sendmail 'zhoufeng@163.com'
end --禁用和启用触发器
--disable 禁用;Enable 启用
alter table 仓库备份
disable trigger db_trigger1 alter table 仓库备份
Enable trigger db_trigger1 alter table 仓库备份
disable trigger db_trigger1, db_trigger2 alter table 仓库备份
Enable trigger all --保护数据表不被修改和删除的触发器
create trigger db_DDL_trigger1
on database
for drop_table,Alter_table
as
begin
print '不能修改和删除当前数据库中的数据表!'
rollback
end drop table 仓库备份 --保护数据库不被删除的触发器
create trigger db_DDL_trigger2
on all server
for drop_database
as
begin
print '不能删除当前服务器中的任何数据库'
rollback
end drop database db_business --记录数据库操作日志的触发器
create table 记录日志表
(
日志编号 int identity(1,1) primary key,
事件 varchar(600) null,
所用语句 varchar(8000) null,
操作者 varchar(60) null,
发生时间 datetime null
) create trigger db_DDL_trigger3
on database
for DDL_Database_level_Events
as
begin
declare @log xml
set @log =Eventdata()
insert into 记录日志表(事件,所用语句,操作者,发生时间) values
(
@log.value('(/Event_Instance/EventType)[1]','nvarchar(100)'),
@log.value('(/Event_Instance/TSQLCommand)[1]','nvarchar(2000)'),
Convert(nvarchar(100),Current_user),
Getdate()
)
end --test
create table db_table2
(
仓库编号 int not null,
仓库号 varchar(50) not null,
城市 varchar(50) not null,
面积 int
) select * from 记录日志表
------------------------------------------
--事务
begin transaction update_data
use db_business
go
update 职工备份 set 姓名='事务修改' where 职工号='zg2'
rollback transaction update_data --回滚 --test
select * from 职工备份 -------------------------- begin transaction update_data
use db_business
go
update 职工备份 set 姓名='事务修改' where 职工号='zg2'
commit transaction update_data --提交 --test
select * from 职工备份
BEGIN TRY
BEGIN TRANSACTION trans1 --开始事务 trans1称事务保存点可选(提交、回滚类似)
INSERT INTO dbo.TestTable( D_Name, D_Password, D_Else )VALUES ( '11','22','33')
INSERT INTO dbo.TestTable( D_Name, D_Password, D_Else )VALUES ( '11','22','33','4444')
COMMIT TRANSACTION trans1--提交事务
END TRY
BEGIN CATCH
ROLLBACK TRANSACTION trans1--回滚事务 上面插入有误 全部回滚
END CATCH

SqlServer和Oracle中一些常用的sql语句8 触发器和事务的更多相关文章
- SqlServer和Oracle中一些常用的sql语句9 SQL优化
--SQL查询优化 尽量避免使用or,not,distinct运算符,简化连接条件 /*Or运算符*/ use db_business go select * from 仓库 where 城市='北京 ...
- SqlServer和Oracle中一些常用的sql语句5 流程控制语句
--在sql语句中 begin...end 用来设定一个程序块 相关于c#中的{} declare @yz real,@w int --声明变量 set @w=120 --为变量赋值 if @w< ...
- SqlServer和Oracle中一些常用的sql语句10 特殊应用
--482, ORACLE / SQL SERVER --订购数量超过平均值的书籍 WITH Orders_Book AS ( SELECT Book_Name, SUM(Qty) Book_Qty ...
- SqlServer和Oracle中一些常用的sql语句3 行列转换
--217, SQL SERVER SELECT Cust_Name , MAX(CASE WHEN Order_Date ='2009-08-01' THEN AR END) "2009- ...
- SqlServer和Oracle中一些常用的sql语句6 存储过程
--不带参数的存储过程 CREATE procedure proc_sql1 as begin declare @i int set @i=0 while @i<26 begin print c ...
- SqlServer和Oracle中一些常用的sql语句7 游标
declare db_cursor4 scroll cursor for select * from 供应商 --声明游标 open db_cursor4 --打开游标 fetch first fro ...
- SqlServer和Oracle中一些常用的sql语句4 局部/全局变量
--把wh1仓库号中姓名含有"平"字的职工工资在原来的基础上加288 update 职工备份 set 工资=工资+288 where 仓库号='wh1' and 姓名 like ' ...
- SqlServer 获取字符串中小写字母的sql语句
SQL字符串截取(SubString) 作用:返回第一个参数中从第二个参数指定的位置开始.第三个参数指定的长度的子字符串. 有时候我们会截取字符串中的一些特殊想要的东西,大小写字母.模号.汉字.数字等 ...
- SqlServer 查看备份文件中逻辑文件信息的Sql语句
RESTORE FILELISTONLY FROM DISK = 'D:\All\DataBase\(2013-12-18)-1.bak' 用来查看备份文件中的逻辑文件信息. 相关信息:SqlServ ...
随机推荐
- svn to git
SVN to git 配置用户: #git config --global user.name "root"#git config --global user.email &quo ...
- PHP中如何调试?
比如有个数组: $arr = array('A' => 'bobi','B' => 'hehe'); echo $arr; //Array 只打印出了变量 ...
- 软工+C(2017第4期) Alpha/Beta换人
// 上一篇:超链接 // 下一篇:工具和结构化 注:在一次软件工程讨论课程进度设计的过程中,出现了这个关于 Alpha/Beta换人机制的讨论,这个机制在不同学校有不同的实施,本篇积累各方观点,持续 ...
- 展示博客(Beta阶段)
展示博客 0x00 团队成员 成员 博客地址 简介 黄建英 http://www.cnblogs.com/smilehjy/ beta阶段的新成员,负责前端界面调整 谢晓萍 http://www.cn ...
- 201521123054《Java程序设计》第4周总结
1. 本周学习总结 2. 书面作业 注释的应用 使用类的注释与方法的注释为前面编写的类与方法进行注释,并在Eclipse中查看.(截图) 面向对象设计(大作业1,非常重要) **2.1 将在网上商城购 ...
- 201521123095 《Java程序设计》第2周学习总结
1. 本周学习总结 学会了使用码云管理代码,使用eclipse关联jdk源代码: 还学习了Java语言中各种数据类型以及运算符. 2. 书面作业 1.使用Eclipse关联jdk源代码,并查看Stri ...
- 多线程面试题系列(12):多线程同步内功心法——PV操作上
上面的文章讲解了在Windows系统下实现多线程同步互斥的方法,为了提高在实际问题中分析和思考多个线程之间同步互斥问题的能力,接下来将讲解PV操作,这也是操作系统中的重点和难点.本文将会先简要介绍下P ...
- 在windows下安装flex和bison
学习Stellar-core 需要依赖项flex .bison .gcc三个依赖项 下载得网址:链接: https://pan.baidu.com/s/1mitCLcs 密码: 3jaj 通过 w ...
- lintcode.67 二叉树中序遍历
二叉树的中序遍历 描述 笔记 数据 评测 给出一棵二叉树,返回其中序遍历 您在真实的面试中是否遇到过这个题? Yes 样例 给出二叉树 {1,#,2,3}, 1 \ 2 / 3 返回 [1,3, ...
- POJ-2299 Ultra-QuickSort (树状数组,离散化,C++)
Problem Description In this problem, you have to analyze a particular sorting algorithm. The algorit ...