SQL Server 2005系列教学(16) 触发器

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介:
触发器:
本质是一个存储过程
常见的触发器类型:
插入触发器  insert
删除触发器  delete 
更新触发器  update
插入触发器:
语法:
create trigger 名称
on 表名  for insert
as
begin
   代码
end

select  * from users
insert into users values ('张三','男',20,40)
例:禁止插入新记录
alter trigger inse01
on users for insert
as
begin
  if exists( select  * from  inserted)   或者写成 count(*)
    rollback
   print '禁止插入新员工信息'
end
insert into users values ('张三风','男',20,40)
select  * from users
--simpletrigger.sql
--简单的触发器
use northwind
例:
alter trigger 简单触发器 on dufei for insert as 
declare @ID int,@username nvarchar(50)
set @ID = @@identity
set @username = (select username from dufei where  ID=@ID)
print '最后写入的记录的编号是:' + convert(nvarchar,@ID) + '  用户名是:' + @username
go
insert dufei (username) values('吴小华')
但如果在print 后加一个rollback结果就不同了。说明是手插入到表中了,但又回滚了。
select @@identity
create table dufei
(id  int identity(1,1),
username varchar(10))

--drop trigger reminder
insert into employees(LastName,FirstName)
values('hahaha1','xixixi1')
select * from employees
--禁止触发器
alter table employees disable trigger reminder
 
--启用触发器
alter table employees enable trigger reminder
select * from employees
解除触发器:(删除触发器)
drop trigger 名称
drop trigger inse01

禁止插入行政部新员工
alter trigger inse02
on yuangong for insert
as
begin
if exists(select * from inserted where 部门='行政部' )
begin
  rollback
  print  '你的权限不够,不能插入行政部新员工!'
end
end
select  * from yuangong
delete from yuangong  where 姓名='于洋'
insert into yuangong values  ('0001','于洋','男',20,'2007-12-26','河南',3000,2000,500,1,'123456','保安部')
count(*)

create trigger inse03
on yuangong for insert
as
begin
     if (select count(*) from inserted  where 部门='' )>0
     begin
          rollback
          print  '不能插入新记录'
     end
end
drop trigger inse03
insert into yuangong values  ('0001','于洋','男',20,'2007-12-26','河南',3000,2000,500,1,'123456','保安部')

删除触发器:
 create trigger 名称
 on 表名 for delete
 as
 begin
   代码
  end
用到一个临时表: deleted 存放的是准备删除的记录
禁止删除技术部的员工
  alter trigger del01
  on  yuangong for delete
  as
  begin
     if exists(select * from deleted  where 部门='人事部')
     begin
         rollback
         print  '不能删除人事部员工'
     end
  end
select * from yuangong
delete from yuangong where 编号='0006'

更新触发器:
用到临时表: 两个: 
inserted
deleted
禁止用户更新:
create  trigger upd01
on yuangong for update
as
begin
    if exists(select  * from inserted)
    begin
        rollback
        print  '不允许更改数据!'
    end
end
禁止更新基本工资和奖金
create  trigger upd01
on yuangong for update
as
begin
    if update(基本工资) or update(奖金)
    begin
        rollback
        print  '不允许更改数据!'
    end
end
 
select  * from yuangong
update yuangong set 年龄=30  where 姓名='于洋'
Create unique ix_name   on hr (姓,名)
create [unique][clustered][nonstered] index on 数据表名称(列名称)
只允许更改姓名,性别,年龄
create trigger upda02
on yuangong for update
as
begin
   if update(姓名) or update(性别)  or update (年龄)
    begin
        commit
     end
    else
    begin
      rollback
      print  '不能修改姓名,性别,年龄之外的数据'
     end
end

测试:
select * from yuangong
update yuangong set  姓名='于小洋',性别 ='女',年龄=30   where 姓名='于洋'
update yuangong set 编号='0008' where 姓名='于小洋'

create  table 学生表
(
姓名 nvarchar(8) not null primary key,
性别 nvarchar(2) not null ,
年龄 tinyint
)
create table 人数表
(
性别 nvarchar(2),
人数 int
)
insert 人数表 values ('女',0)
insert 人数表 values ('男',0)
drop TABLE 学生表

select  * from 学生表
select  * from 人数表
create trigger test2
on 学生表 for insert
as
begin
   if exists (select * from inserted where 性别='男')
   begin
     update 人数表 set 人数=(select count(*) from 学生表 group by 性别 having 性别='男')
     where 性别='男'
   end
   else
   begin
     if exists (select * from inserted where 性别='女')
      begin
         update 人数表 set 人数=(select count(*) from 学生表 group by 性别 having 性别='女')
          where 性别='女'
       end
   end
end

select  * from 学生表
select  * from 人数表
insert into 学生表 values ('小王','男',20)
insert into 学生表 values ('小胡','男',19)
alter trigger upd001
on 学生表  for  insert
as
begin
  
 update 人数表  set  人数=人数+1  where 性别 in (select 性别 from inserted )
end
drop trigger test2

select  * from 学生表
select  * from 人数表
insert into 学生表 values ('小孙','女',20)
insert into 学生表 values ('小纪','女',19)
delete from  学生表  where 性别='女'
实现删除学生记录
create trigger dele01
on 学生表 for delete
as
if exists(select  * from deleted)
 begin
    update 人数表 set 人数=(select count(*) from 学生表 where 性别='男')  where 性别='男'
        update 人数表 set 人数=(select count(*) from 学生表 where 性别='女')  where 性别='女' 
 end
测试:  分开删除






 本文转自 dufei 51CTO博客,原文链接:http://blog.51cto.com/dufei/80768,如需转载请自行联系原作者

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
9月前
|
SQL IDE Java
Java连接SQL Server数据库的详细操作流程
Java连接SQL Server数据库的详细操作流程
|
6月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
8月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
207 13
|
8月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
123 9
|
8月前
|
SQL 存储 网络安全
关系数据库SQLserver 安装 SQL Server
【7月更文挑战第26天】
103 6
|
7月前
|
SQL 存储 数据管理
深入理解SQL中的触发器
【8月更文挑战第31天】
221 0
|
8月前
|
存储 SQL C++
对比 SQL Server中的VARCHAR(max) 与VARCHAR(n) 数据类型
【7月更文挑战7天】SQL Server 中的 VARCHAR(max) vs VARCHAR(n): - VARCHAR(n) 存储最多 n 个字符(1-8000),适合短文本。 - VARCHAR(max) 可存储约 21 亿个字符,适合大量文本。 - VARCHAR(n) 在处理小数据时性能更好,空间固定。 - VARCHAR(max) 对于大文本更合适,但可能影响性能。 - 选择取决于数据长度预期和业务需求。
638 1
|
8月前
|
SQL Oracle 关系型数据库
MySQL、SQL Server和Oracle数据库安装部署教程
数据库的安装部署教程因不同的数据库管理系统(DBMS)而异,以下将以MySQL、SQL Server和Oracle为例,分别概述其安装部署的基本步骤。请注意,由于软件版本和操作系统的不同,具体步骤可能会有所变化。
653 3
|
7月前
|
SQL 安全 Java
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“The server selected protocol version TLS10 is not accepted by client
633 0
|
8月前
|
SQL 存储 安全
数据库数据恢复—SQL Server数据库出现逻辑错误的数据恢复案例
SQL Server数据库数据恢复环境: 某品牌服务器存储中有两组raid5磁盘阵列。操作系统层面跑着SQL Server数据库,SQL Server数据库存放在D盘分区中。 SQL Server数据库故障: 存放SQL Server数据库的D盘分区容量不足,管理员在E盘中生成了一个.ndf的文件并且将数据库路径指向E盘继续使用。数据库继续运行一段时间后出现故障并报错,连接失效,SqlServer数据库无法附加查询。管理员多次尝试恢复数据库数据但是没有成功。

热门文章

最新文章