当前位置:首页 » 编程语言 » sql程序可以用于触发器中吗
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

sql程序可以用于触发器中吗

发布时间: 2022-10-31 02:38:22

Ⅰ 用sql写触发器

--此题唯一的难度是用户名 假设用户名已保存在表CurrentUser中
--给出插入操作的触发器创建 其他类似
CREATE TRRIGER MYTR1
ON A
FOR INSERT
AS
DECLARE @UserName varchar(20)
SELECT @UserName=UserName from CurrentUser
INSERT INTO C (TableName,Type,dDate,UserName) VALUES ('A','Insert',getdate(),@UserName)
GO

Ⅱ SQL中触发器有什么作用

触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。 触发器可以从 DBA_TRIGGERS ,USER_TRIGGERS 数据字典中查到。SQL3的触发器是一个能由系统自动执行对数据库修改的语句。
触发器与存储过程的唯一区别是触发器不能执行EXECUTE语句调用,而是在用户执行Transact-SQL语句时自动触发执行。
触发器可以查询其他表,而且可以包含复杂的SQL语句。它们主要用于强制服从复杂的业务规则或要求。例如:您可以根据客户当前的帐户状态,控制是否允许插入新订单。
触发器也可用于强制引用完整性,以便在多个表中添加、更新或删除行时,保留在这些表之间所定义的关系。然而,强制引用完整性的最好方法是在相关表中定义主键和外键约束。如果使用数据库关系图,则可以在表之间创建关系以自动创建外键约束。
SQL Server 包括三种常规类型的触发器:DML 触发器、DDL 触发器和登录触发器。
语法为:
CREATE TRIGGER `<databaseName>`.`<triggerName>`
< [ BEFORE | AFTER ] > < [ INSERT | UPDATE | DELETE ] >
ON [dbo]<tableName> //dbo代表该表的所有者
FOR EACH ROW
BEGIN
--do something
END
触发器可通过数据库中的相关表实现级联更改,不过,通过级联引用完整性约束可以更有效地执行这些更改。触发器可以强制比用CHECK约束定义的约束更为复杂的约束。与 CHECK 约束不同,触发器可以引用其它表中的列。例如,触发器可以使用另一个表中的 SELECT 比较插入或更新的数据,以及执行其它操作,如修改数据或显示用户定义错误信息。触发器也可以评估数据修改前后的表状态,并根据其差异采取对策。一个表中的多个同类触发器(INSERT、UPDATE 或 DELETE)允许采取多个不同的对策以响应同一个修改语句。
约束和触发器在特殊情况下各有优势。触发器的主要好处在于它们可以包含使用 Transact-SQL 代码的复杂处理逻辑。因此,触发器可以支持约束的所有功能;但它在所给出的功能上并不总是最好的方法。实体完整性总应在最低级别上通过索引进行强制,这些索引或是 PRIMARY KEY 和 UNIQUE 约束的一部分,或是在约束之外独立创建的。假设功能可以满足应用程序的功能需求,域完整性应通过 CHECK 约束进行强制,而引用完整性(RI) 则应通过 FOREIGN KEY 约束进行强制。在约束所支持的功能无法满足应用程序的功能要求时,触发器就极为有用。
CHECK 约束只能根据逻辑表达式或同一表中的另一列来验证列值。如果应用程序要求根据另一个表中的列验证列值,则必须使用触发器。约束只能通过标准的系统错误信息传递错误信息。如果应用程序要求使用(或能从中获益)自定义信息和较为复杂的错误处理,则必须使用触发器。
触发器可通过数据库中的相关表实现级联更改;不过,通过级联引用完整性约束可以更有效地执行这些更改。触发器可以禁止或回滚违反引用完整性的更改,从而取消所尝试的数据修改。当更改外键且新值与主键不匹配时,此类触发器就可能发生作用。例如,可以在 titleauthor.title_id 上创建一个插入触发器,使它在新值与 titles.title_id 中的某个值不匹配时回滚一个插入。不过,通常使用 FOREIGN KEY 来达到这个目的。
如果触发器表上存在约束,则在 INSTEAD OF 触发器执行后但在 AFTER 触发器执行前检查这些约束。如果约束破坏,则回滚 INSTEAD OF 触发器操作并且不执行 AFTER 触发器。
实例1:insert触发器
create trigger tri_insert
on student
for insert
as
declare @student_id char(10)
select @student_id=s.student_id from
student s inner join inserted i
on s.student_id=i.student_id
if @student_id='0000000001'
begin
raiserror('不能插入1的学号!',16,8)
rollback tran
end
go
实例2:update触发器
create trigger tri_update
on student
for update
as
if update(student_id)
begin
raiserror('学号不能修改!',16,8)
rollback tran
end
go
实例3:delete触发器示
create trigger tri_delete
on student
for delete
as
declare @student_id varchar(10)
select @student_id=student_id from deleted
if @student_id='admin'
begin
raiserror('错误',16,8)
rollback tran
end

Ⅲ SQL 触发器 应用

写触发器当然会用到这两个表,它们存放的是你刚刚进行操作后的数据,可以根据临时表里的数据来编写将要触发的动作
比如删除表中id=1的数据时触发,判断deleted里是否存在id=1,如果存在,则print‘不能删除id=1的记录’,回滚。这样就可以保证id=1这条记录永远不会被误删

c语言怎么使用sql触发器

c语言怎么使用sql触发器:
定义: 何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。
常见的触发器有三种:分别应用于Insert , Update , Delete 事件。

我为什么要使用触发器?比如,这么两个表:

Create Table Student( --学生表
StudentID int primary key, --学号
....
)

Create Table BorrowRecord( --学生借书记录表
BorrowRecord int identity(1,1), --流水号
StudentID int , --学号
BorrowDate datetime, --借出时间
ReturnDAte Datetime, --归还时间
...
)

用到的功能有:
1.如果我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同时更改借书记录表的学号);
2.如果该学生已经毕业,我希望删除他的学号的同时,也删除它的借书记录。
等等。

这时候可以用到触发器。对于1,创建一个Update触发器:

Create Trigger truStudent
On Student --在Student表中创建触发器
for Update --为什么事件触发
As --事件触发后所要做的事情
if Update(StudentID)
begin

Update BorrowRecord
Set StudentID=i.StudentID
From BorrowRecord br , Deleted d ,Inserted i --Deleted和Inserted临时表
Where br.StudentID=d.StudentID

end

理解触发器里面的两个临时的表:Deleted , Inserted 。注意Deleted 与Inserted分别表示触发事件的表“旧的一条记录”和“新的一条记录”。
一个数据库系统中有两个虚拟表用于存储在表中记录改动的信息,分别是:
虚拟表Inserted 虚拟表Deleted

在表记录新增时 存放新增的记录 不存储记录
修改时 存放用来更新的新记录 存放更新前的记录
删除时 不存储记录 存放被删除的记录

一个Update 的过程可以看作为:生成新的记录到Inserted表,复制旧的记录到Deleted表,然后删除Student记录并写入新纪录。

对于2,创建一个Delete触发器
Create trigger trdStudent
On Student
for Delete
As
Delete BorrowRecord
From BorrowRecord br , Delted d
Where br.StudentID=d.StudentID

从这两个例子我们可以看到了触发器的关键:A.2个临时的表;B.触发机制。

Ⅳ 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 --结束标记

Ⅵ SQL触发器编程

1、
在“Borrow”表中创建一个触发器ins_borrower_tr,当向“借阅”表中插入记录时,“借书日期”不能为空值,“还书日期”必须为空值。不满足上述条件则不允许向“借阅”表中插入记录,满足上述条件则允许插入,同时得到该书的应还日期,且“图书”表中对应的图书数量要减1,此操作对应读者的借书行为。
----“借书日期”不能为空值
可以通过
IS
NOT
NULL
来设置,不需要触发器;
----“还书日期”必须为空值
可以通过设置默认值实现,就是不管输入何值,最后都清空;
----“应还日期”是通过“借书日期”计算得出、“图书”表中对应的图书数量要减1
:两个功能通过触发器实现;
CREATE
TRIGGER
ins_borrower_tr

ON
Borrow

FOR
INSERT
AS
BEGIN

UPDATE
Borrow
SET
应还日期
=
借书日期
+ n
FROM
Borrow,Inserted
WHERE
Borrow.b_id,
=
Inserted.b_id

【其他的类似】
END
GO

2、在“Borrow”表中创建一个触发器del_borrower_tr,当删除“借阅”表中的某个记录时,若“还书日期”为空值,则不允许删除该记录。
----
这个可以通过触发器实现

3、在“Borrow”表中创建一个触发器update_return_tr,当更新“借阅”表中的某个记录时,只能更新“还书日期”字段,其他字段不能更新,请计算出是否过期并给出罚款信息(过期一天罚款0.1元)。如果更新,“book”表中对应的图书数量要加1。此操作对应读者的还书行为。
----只能更新“还书日期”字段,其他字段不能更新:这个不好实现的,因为如果程序中是可写的,就有点麻烦了!建议在程序中设置其他字段修改时为只读属性。
----其他科通过触发器实现。

Ⅶ 触发器与sql语句

肯定是用事物.
涉及多表插入嘛
要保证数据的完整性 这是必须的.
再说触发器就是一特殊的存储过程
从服务器的上的效率来说 两者区别并不大
而且 触发器 很不好控制 一般不推荐使用

Ⅷ sql 事务里可以加触发器吗

触发器是创建在表上的。

执行代码中通常不用,这么干也不合理。

Ⅸ sql在什么情况使用触发器谢谢

触发器用于希望各种对数据的增删改立刻做出处理的情况,是一种特殊类型的存储过程,不由用户直接调用,它在指定的表中的数据发生变化时自动生效,唤醒调用触发器以响应 INSERT、UPDATE 或 DELETE 语句。
触发器的主要好处在于它们可以包含使用 Transact-SQL 代码的复杂处理逻辑。因此,触发器可以支持约束的所有功能;但它在所给出的功能上并不总是最好的方法。触发器也可以评估数据修改前后的表状态,并根据其差异采取对策。

由于触发器是自动执行的,所以当sql操作的表存在异常情况下,会出现各类难以预计的异常,而且难以实现复杂的业务逻辑处理,所以在大型应用系统中一般不用触发器,而用存储过程或中间件统一进行数据的处理。