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

sql触发器写在程序里面

发布时间: 2022-06-20 21:54:06

A. sql触发器写法

触发器(trigger)是SQL server 提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作( insert,delete, update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。 触发器可以从 DBA_TRIGGERS ,USER_TRIGGERS 数据字典中查到。SQL3的触发器是一个能由系统自动执行对数据库修改的语句。
语法:
DELIMITER |
CREATE TRIGGER `<databaseName>`.`<triggerName>`
< [ BEFORE | AFTER ] > < [ INSERT | UPDATE | DELETE ] >
ON [dbo]<tableName> //dbo代表该表的所有者
FOR EACH ROW
BEGIN
--do something
END |
例子:
-- 插入时执行触发器
set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
GO
create trigger [dbo].[rscOpenInsert]
on [dbo].[RSC_INFO]
for insert
as www.2cto.com
DECLARE
@v_rscID varchar(50),
@v_status int
begin
select @v_rscID=rscID,@v_status=status from inserted;
--取得当前资源信息status>4 才插入信息
if @v_status > 4
begin
insert into RSC_OPEN_SYNCHRONOUS(rscID,opStatus,opDateTime) values (@v_rscID,'insert',getDate())
end
end

--- 更新时执行触发器

set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
GO
create trigger [dbo].[rscOpenUpdate]
on [dbo].[RSC_INFO]
for update
as
DECLARE
@v_rscID varchar(50),
@v_status int
begin www.2cto.com
select @v_rscID=rscID,@v_status=status from inserted;
--取得当前资源信息status>4 才更新信息
if @v_status > 4
begin
update RSC_OPEN_SYNCHRONOUS set opStatus = 'update', opDateTime = getDate() where rscID=@v_rscID
end
end

B. SQL触发器编写

基本语法 create trigger tri_name on table for insert/update/deleted as SQL code 例: create trigger tri_mc(tri_mc:自定义触发器的名称) on table (table:触发的表名) for insert (触发类型:insert,插入数据触发 update,更新数据触发 delete,删除数据触发) as declare @kssj datetime (定义一个变量,做中间处理) declare @sqbh char(40) select @kssj = kssj,@sqbh = sqbh from inserted (插入数据时,插入的数据在表 inserted 更新数据时,更新后的数据在表 inserted 更新前的数据在表中 deleted 删除数据时,删除的数据在表 deleted 不同的操作可以,取出不同的中间数据,做处理,例子中取出插入的数据) update table2 set isks = 1,kksj = @kssj where sqbh = @sqbh (根据中间处理做相应操作,例子的处理为,将插入的值同步更新到另一个表)

C. 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。此操作对应读者的还书行为。
----只能更新“还书日期”字段,其他字段不能更新:这个不好实现的,因为如果程序中是可写的,就有点麻烦了!建议在程序中设置其他字段修改时为只读属性。
----其他科通过触发器实现。

D. 如何在代码中实现SQL中的触发器

触发器是自动触发的,比如:新增记录、修改记录、删除记录的时候触发。

E. 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.触发机制。

F. SQl中触发器怎样执行的

创建触发器 是特殊的存储过程,自动执行,一般不要有返回值。

1、后触发器 (AFTER,FOR)先执行对应语句,后执行触发器中的语句。

2、前触发器 并没有真正的执行触发语句(insert,update,delete),而是执行触发后的语句。

3、行级触发器 (FOR EACH ROW) 在SQL server 中不存在。

(6)sql触发器写在程序里面扩展阅读:

创建触发的语法

CREATE TRIGGER trigger_name --触发器名称

ON table_name --触发的表

[WITH ENCRYPTION]

FOR [DELETE, INSERT, UPDATE] --选择触发器类型

AS --触发后要做的语句

T-SQL语句

GO --结束标记

G. sql server里面的触发器怎么写

基本语法
create trigger tri_name
on table
for insert/update/deleted
as
SQL code

例:
create trigger tri_mc(tri_mc:自定义触发器的名称)
on table (table:触发的表名)
for insert (触发类型:insert,插入数据触发 update,更新数据触发 delete,删除数据触发)
as
declare @kssj datetime (定义一个变量,做中间处理)
declare @sqbh char(40)
select @kssj = kssj,@sqbh = sqbh from inserted
(插入数据时,插入的数据在表 inserted
更新数据时,更新后的数据在表 inserted 更新前的数据在表中 deleted
删除数据时,删除的数据在表 deleted
不同的操作可以,取出不同的中间数据,做处理,例子中取出插入的数据)
update table2 set isks = 1,kksj = @kssj where sqbh = @sqbh
(根据中间处理做相应操作,例子的处理为,将插入的值同步更新到另一个表)

H. SQL中触发器的代码写在哪里

oracle是写在pl/SQL块中
下面就是一个触发器
每执行一次update操作就显示一定的信息
CREATE TRIGGER before_update_trigger
before update of price
on procts
begin
if new.price<old.price then
--输出信息
DBMS_OUTPUT.PUT_LINE('价格降低了');
else
DBMS_OUTPUT.PUT_LINE('价格升高了');
end if;
end before_update_trigger;
这个触发器会在执行update语句之间触发

I. sql怎么写触发器

基本语法格式
create trigger tri_name
on table
for insert/update/deleted
as
SQL code

例:
create trigger tri_mc(tri_mc:自定义触发器的名称)
on table (table:触发的表名)
for insert (触发类型:insert,插入数据触发 update,更新数据触发 delete,删除数据触发)
as
declare @kssj datetime (定义一个变量,做中间处理)
declare @sqbh char(40)
select @kssj = kssj,@sqbh = sqbh from inserted
(插入数据时,插入的数据在表 inserted
更新数据时,更新后的数据在表 inserted 更新前的数据在表中 deleted
删除数据时,删除的数据在表 deleted
不同的操作可以,取出不同的中间数据,做处理,例子中取出插入的数据)
update table2 set isks = 1,kksj = @kssj where sqbh = @sqbh
(根据中间处理做相应操作,例子的处理为,将插入的值同步更新到另一个表)

J. SQL中触发器创建与调用

先给你举个触发器的实例:
先创建两个表
Create Table Student( --学生表
StudentID int primary key, --学号
....
)

Create Table BorrowRecord( --学生借书记录表
BorrowRecord int identity(1,1), --流水号
StudentID int , --学号
BorrowDate datetime, --借出时间
ReturnDAte Datetime, --归还时间
...
)
创建触发器
Create Trigger truStudent
On Student --在Student表中创建触发器
for Update --为什么事件触发,在这里就是修改的时候会执行这个触发器,一旦你修改Student表,就会执行
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