當前位置:首頁 » 編程語言 » sql觸發器編寫
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

sql觸發器編寫

發布時間: 2023-03-12 16:39:17

1. sql觸發器怎麼做

CREATE
TRIGGER
[km]
ON
員工表
AFTER
DELETE
AS
BEGIN
DELETE
FROM
工資表
WHERE
員工編號
IN
(SELECT
員工編號
FROM
deleted)
END
CREATE
TRIGGER
[gf]
ON
員工表
AFTER
UPDATE
AS
BEGIN
UPDATE
工資表
SET
部門編號=(SELECT
部門編號
FROM
inserted)
WHERE
員工編號=(SELECT
員工編號
FROM
inserted)
END

2. 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。此操作對應讀者的還書行為。
----只能更新「還書日期」欄位,其他欄位不能更新:這個不好實現的,因為如果程序中是可寫的,就有點麻煩了!建議在程序中設置其他欄位修改時為只讀屬性。
----其他科通過觸發器實現。

3. SQL 觸發器怎麼寫

CREATETRIGGER[dbo].[TRG_A]
ON[dbo].[A]
AFTERUPDATE
AS
BEGIN
INSERTINTOB
(
[FILD]
,[BEFORE]
,[AFTER]
)
SELECT'DATE'
,DEL.[DATE]
,UPD.[DATE]
FROMDELETEDDEL
INNERJOININSERTEDUPD
ONDEL.ID=UPD.ID
ANDDEL.[DATE]!=UPD.[DATE];

INSERTINTOB
(
[FILD]
,[BEFORE]
,[AFTER]
)
SELECT'NAME'
,DEL.[NAME]
,UPD.[NAME]
FROMDELETEDDEL
INNERJOININSERTEDUPD
ONDEL.ID=UPD.ID
ANDDEL.[NAME]!=UPD.[NAME]
END

4. SQL觸發器怎麼做

二樓的說的對,insert
into...select
語句是復製表a的數據到表b里,而且表2不能自定義,是由語句創建的,如果表b已經存在則會出錯.
如果樓主要執行insert
into...select,首先要判斷插入的表是否已經存在,如果存在要將其刪除後在執行.
樓主如果你只是想把剛插入的數據的那3列在插入到另一個表裡,完全沒必要那樣做,直接從inserted表(這個表只在insert觸發器適用)里讀就能讀的到剛插入的內容了,讀取出來後在用insert
語句插入到另一個表即可.

5. SQL求助 插入刪除修改的觸發器代碼編寫

---創建測試表:
Create Table MyTest(
id int identity(1,1) not null primary key,
[name] varchar(100) null
)
--創建觸發器:
CREATE TRIGGER trigtest--創建觸發器trigtest
ON mytest--在表mytest上建
for INSERT,DELETE,UPDATE--為插入,刪除,修改
AS
BEGIN
declare @a int,
@b int,
@id int,
@name varchar(100),
@oldId int,--原ID號
@oldName varchar(100)--原來的name
set @a=0
set @b=0
if exists(select * from inserted)--如果存在插入新的數據則設置@a=1
begin
set @a=1
end
if exists(select * from deleted)--如果存在刪除數據則設置@b=1
begin
set @b=1
end
if (@a=1)and(@b=0)--新增:當插入表inserted存在數據而刪除表deleted不存數據時,為新增操作。
begin
select @id=id,@name=name from inserted
print '增加了ID號為【'+cast(@id as varchar(5))+'】Name為【'+@name+'】的數據!'
end
if (@a=1)and(@b=1)--修改:當插入表insertedt和刪除表deleted都存在數據時,為修改操作。
begin
select @id=id,@name=name from inserted
select @id=id,@oldname=name from deleted
print '修改了ID號為【'+cast(@id as varchar(5))+'】的數據Name由【'+@oldname+'】變為【'+@name+'】'
end
if (@a=0)and(@b=1)--刪除:當插入表inserted不存在數據而刪除表deleted存在數據時,為刪除操作。
begin
select @id=id,@name=name from deleted
print '刪除了ID號為【'+cast(@id as varchar(5))+'】Name為【'+@name+'】的數據!'
end
END

6. 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

7. 用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