㈠ sql实验:触发器
-------1、
CREATE TRIGGER tr_insert
ON 学生表
FOR INSERT
AS
DECLARE @Class_ID int,
@Stu_id int
select top 1 @Class_ID=课号 from (select 课号,count(*) as total from 选课表 group by 课号) t1 order by t1.total desc
select @Stu_id=学号 from inserted
insert into 选课表 values(@Stu_id, @Class_ID, 0)
GO
--------2、
CREATE TRIGGER tr_delete
ON 学生表
FOR DELETE
AS
DECLARE @Stu_id int
select @Stu_id=学号 from deleted
if exists (select 1 from 选课表 where 学号=@Stu_id)
begin
RAISERROR ('拒绝删除学号为%d的记录,因该生有选课记录',@Stu_id)
ROLLBACK TRANSACTION
end
/*要求在删除学生信息同时,将相关表中的信息全部删除(因不知道你的表,你自己添加根据@Stu_id(学号)来在下面添加额外对应表的删除吧*/
GO
㈡ 怎么用SQL做触发器
我写的,没有经过测试,仅供参考,如果不对的话请原谅
CREATE TRIGGER books_rt_upd
ON books_rt
FOR UPDATE
AS
IF UPDATE (return_date)
BEGIN
-- 定义 借书日期
declare @lend_date date
-- 定义 应还书日期
declare @return_date date
-- 定义 超出天数
declare @exday int
-- 定义 超出价格
declare @exfee decimal
-- 定义 用户id
declare @userid
-- 定义 用户id
declare @usertype
-- 修改用户归还日期,和借书的id号
select @return_date=return_date , @lendid = lendid from INSERTED
select
@lend_date=lend_date,@userid=userid ,@usertype=@usertype
from
books_rt
where lendid in (select lendid from INSERTED)
-- 计算超出多少天并乘以价格
set @exday = @return_date - @lend_date
-- 根据用户级别察看是否超过天数
IF @usertype= '01' begin
if @exday > '10' --01级别可以借书10天
begin
set @exday = @exday - 10
end
end
IF @usertype= '02' begin
if @exday > '20' --02级别可以借书20天
begin
set @exday = @exday - 20
end
end
set @exfee = @exday * 0.3
-- 修改用户帐户表
update user_account set user_fee = userfee - @exfee
where userid = @userid
END
㈢ SQL中,触发器是什么
1. 基本概念x0dx0a触发器是特殊的存储过程,基于一个表创建,主要作用就是实现由主键和外键所不能保证的复杂的参照完整性和数据一致性。x0dx0a当触发器所保护的数据发生变化(update,insert,delete)后,自动运行以保证数据的完整性和正确性。通俗的说:通过一个动作(update,insert,delete)调用一个存储过程(触发器)。肢早x0dx0a2. 类型x0dx0a(1)DML触发器x0dx0a在数据库中发生数据操作语言(DML)事件时将启用。DML 事件包括在指定表或视图中修改数据的 INSERT 语句、UPDATE 语句或 DELETE 语句。DML 触发器可以查询其他表,还可以包含复杂的 T-SQL 语句。系统将触发器和触发它的语句作为可在触发器内回滚的单个事务对待,如果检测到错误(例如,磁盘空间不足),则整个事务即自动回滚。x0dx0a(2)DDL 触发器x0dx0aSQL Server 2005 的新增功能。当服务器或数据库中发生数据定义语言(DDL)事件时将调用这些触发器。但与DML触发器不同的是,它们不会为响应针对表或视图的UPDATE、INSERT或DELETE语句而激发,相反,它们会为响应多种数据定义语言(DDL)语句而激发。这些语句主要是以CREATE、ALTER和DROP开头的语句。DDL触发器可用于管理任务,例如审核和控制数据库操作。x0dx0a 创建DML触发器x0dx0a1. 使用存储过程模板创建存储过程x0dx0a在【对象资源管理器】窗口中,展开“数据库”节点,再展历数雀开所选择的具体数据库节点,再展开“表”节点,右击要创建触发器的“表”,选择“新建触发器”命令,如图所示:x0dx0a在右侧查询编辑器中出现触发器设计模板,用户可以在此基础上编辑触发器,单击“执行”按钮,即可创建该触发器。x0dx0ax0dx0a2. 使用T-SQL语句创建表x0dx0aCREATE TRIGGER 触发器x0dx0aON 表名x0dx0aFOR[update,insert,delete ]x0dx0aAS SQL语句x0dx0a例9-6:创建基于表reader ,DELETE操作的触发器。x0dx0aUSE Libraryx0dx0aGOx0dx0aIF EXISTS(SELECT name FROM sysobjectsx0dx0a WHERE name='reader_d' AND type='TR')x0dx0aDROP TRIGGER reader_d --如果已经存在触发器reader_d则删除x0dx0aGOx0dx0aCREATE TRIGGER reader_d --创建触发器x0dx0aON reader --基于表 x0dx0aFOR DELETE --删除事件x0dx0aASx0dx0aPRINT '数据被删除!' --执行显示输出x0dx0aGOx0dx0a 试试吧!x0dx0a应用:x0dx0aUSE Libraryx0dx0aGOx0dx0aDELETE readerx0dx0awhere Rname='aaa'x0dx0a执行结果:x0dx0a数据被删除!x0dx0a(所影响的行数为 1 行)x0dx0a例9-7:在表borrow中添加借阅信息记录时,得到毕凯该书的应还日期。x0dx0a说明:在表borrow中增加一个应还日期SReturnDate。x0dx0aUSE Libraryx0dx0aIF EXISTS (SELECT name FROM sysobjectsx0dx0aWHERE name ='T_return_date' AND type='TR')x0dx0aDROP TRIGGER T_return_datex0dx0aGOx0dx0aCREATE TRIGGER T_return_date --创建触发器x0dx0aON Borrow --基于表borrowx0dx0aAfter INSERT --插入操作x0dx0aASx0dx0a--查询插入记录INSERTED中读者的类型x0dx0aDECLARE @type int,@dzbh char(10),@tsbh char(15)x0dx0aSET @dzbh=(SELECT RID FROM inserted)x0dx0aSET @tsbh=(SELECT BID FROM inserted)x0dx0aSELECT @type= TypeIDx0dx0aFROM readerx0dx0aWHERE RID=(SELECT RID FROM inserted)--副本x0dx0a/*把Borrow表中的应还日期改为x0dx0a当前日期加上各类读者的借阅期限*/x0dx0aUPDATE Borrow SET SReturnDate=getdate()+x0dx0aCASE x0dx0a WHEN @type=1 THEN 90x0dx0a WHEN @type=2 THEN 60x0dx0a WHEN @type=3 THEN 30x0dx0aENDx0dx0aWHERE RID=@dzbh and BID=@tsbhx0dx0a应用:x0dx0aUSE Libraryx0dx0aINSERT INTO borrow(RID,BID) values(','TP85-08')x0dx0a查看记录:x0dx0a x0dx0a例9-8:在数据库Library中,当读者还书时,实际上要修改表brorrowinf中相应记录还期列的值,请计算出是否过期。x0dx0aUSE Libraryx0dx0aIF EXISTS(SELECT name FROM sysobjectsx0dx0aWHERE name='T_fine_js' AND type='TR')x0dx0aDROP TRIGGER T_fine_jsx0dx0aGOx0dx0aCREATE TRIGGER T_fine_jsx0dx0aON borrowx0dx0aAfter UPDATEx0dx0aASx0dx0aDECLARE @days int,@dzbh char(10),@tsbh char(15)x0dx0aSET @dzbh=(select RID from inserted)x0dx0aSET @tsbh=(select BID from inserted)x0dx0aSELECT @days=DATEDIFF(day, ReturnDate, SReturnDate)x0dx0a--DATEDIFF函数返回两个日期之差,单位为DAYx0dx0aFROM borrowx0dx0aWHERE RID=@dzbh and BID=@tsbhx0dx0aIF @days>0x0dx0a PRINT '没有过期!'x0dx0aELSEx0dx0a PRINT '过期'+convert(char(6),@days)+'天'x0dx0aGOx0dx0a应用:x0dx0aUSE Libraryx0dx0aUPDATE borrow SET ReturnDate=-12-12'x0dx0aWHERE RID=' and BID='TP85-08'x0dx0aGOx0dx0a执行结果:x0dx0a过期-157 天x0dx0a(1 行受影响)x0dx0a例9-9:对Library库中Reader表的 DELETE操作定义触发器。x0dx0aUSE Libraryx0dx0aGOx0dx0aIF EXISTS(SELECT name FROM sysobjectsx0dx0a WHERE name='reader_d' AND type='TR')x0dx0aDROP TRIGGER reader_dx0dx0aGOx0dx0aCREATE TRIGGER reader_dx0dx0aON Readerx0dx0aFOR DELETEx0dx0aASx0dx0aDECLARE @data_yj intx0dx0aSELECT @data_yj=Lendnumx0dx0aFROM deletedx0dx0aIF @data_yj>0x0dx0a BEGINx0dx0a PRINT '该读者不能删除!还有'+convert(char(2),@data_yj)+'本书没还。x0dx0a ROLLBACKx0dx0a ENDx0dx0aELSEx0dx0a PRINT '该读者已被删除!'x0dx0aGOx0dx0a应用:x0dx0aUSE Libraryx0dx0aGOx0dx0aDELETE Reader WHERE RID='x0dx0a执行结果:x0dx0a该读者不能删除!还有4 本书没还。x0dx0a 修改触发器x0dx0aALTER TRIGGER 触发器x0dx0a 删除触发器x0dx0aDROP TRIGGER 触发器x0dx0a 查看触发器x0dx0asp_helptext trigger_namex0dx0asp_helptrigger table_name
㈣ 如何做一个SQL定时触发器
这个不能用触发器,要用作业。
打开企业管理器,进入你服务器名下的“管理”,启动SQL Server代理。然后查看服务器属性,选中“自动启动SQL Server代理”。
接下来进入SQL Server代理下的“作业”,在右边点右键选“新建作业”。
在“常规”里,随便输入一个作业名,分类要选最后一项“数据库维护”。
在“步骤”里,点“新建步骤”,随便输入一个步骤名,数据库选成你的数据库,命令里输入你删除记录的语句,也可以通过“打开”来装载T-SQL脚本,弄好后记得分析一下,没有问题再继续。在“高级”里将“失败时的操作”改成“转到下一步”。
在“调度”里,点“新建调度”,随便输入一个调度名,点“更改”,“发生频率”选每天,“一次发生于”里设置17:00:00,然后点“确定”,再点“确定”,再点“确定”,配置就完成了。
㈤ SQl中触发器怎样执行的
创建触发器 是特殊的存储过程,自动执行,一般不要有返回值。
1、后触发器 (AFTER,FOR)先执行对应语句,后执行触发器中的语句。
2、前触发器 并没有真正的执行触发语句(insert,update,delete),而是执行触发后的语句。
3、行级触发器 (FOR EACH ROW) 在SQL server 中不存在。
(5)sql触发器教程完整版扩展阅读:
创建触发的语法
CREATE TRIGGER trigger_name --触发器名称
ON table_name --触发的表
[WITH ENCRYPTION]
FOR [DELETE, INSERT, UPDATE] --选择触发器类型
AS --触发后要做的语句
T-SQL语句
GO --结束标记