存儲過程可以直接用sql語句創建,觸發器可以在表修改中創建
Create
Procere
name
As
2. SQL觸發器怎麼做
二樓的說的對,insert
into...select
語句是復製表a的數據到表b里,而且表2不能自定義,是由語句創建的,如果表b已經存在則會出錯.
如果樓主要執行insert
into...select,首先要判斷插入的表是否已經存在,如果存在要將其刪除後在執行.
樓主如果你只是想把剛插入的數據的那3列在插入到另一個表裡,完全沒必要那樣做,直接從inserted表(這個表只在insert觸發器適用)里讀就能讀的到剛插入的內容了,讀取出來後在用insert
語句插入到另一個表即可.
3. 怎樣創建一個sql的觸發器
視圖是虛擬表,不能建觸發器,只能在基本表上建
4. SQL里中存儲過程和觸發器,如何創建
觸發器是一種特殊的存儲過程,
2.觸發器是在對表進行插入、更新或刪除操作時自動執行的存儲過程
3.觸發器通常用於強制業務規則
4.觸發器是一種高級約束,可以定義比用CHECK 約束更為復雜的約束
5.可執行復雜的SQL語句(if/while/case)DELETE 觸發器
INSERT 觸發器
UPDATE 觸發器/*----------Insert 插入 觸發器------------*/
Create Trigger Tri_insert
on students /*針對某個表,觸發器是建立在表關繫上的*/
for insert /*採用的是哪種觸發器*/
as
declare @stu_id int;
declare @stu_score varchar(200);
select @stu_id=s_id from inserted /*這里的Inserted 是在創建觸發器時候 系統自動創建的內存表*/
insert into student_Score(s_id,ss_score)values(@stu_id,'100')go
--就是插一條數據進入students中,Tri_insert觸發器就會自動在student_Score插入相關的學生的一條分數的數據
insert into students(s_name,s_classId) values('黃馳',6)select * from student_Score
5. sql觸發器的創建
# 創建insert類型觸發器
--創建insert插入類型觸發器
if (object_id('tgr_classes_insert', 'tr') is not null)
drop trigger tgr_classes_insert
go
create trigger tgr_classes_insert
on classes
for insert --插入觸發
as
--定義變數
declare @id int, @name varchar(20), @temp int;
--在inserted表中查詢已經插入記錄信息
select @id = id, @name = name from inserted;
set @name = @name + convert(varchar, @id);
set @temp = @id / 2;
insert into student values(@name, 18 + @id, @temp, @id);
print '添加學生成功!';
go
--插入數據
insert into classes values('5班', getDate());
--查詢數據
select * from classes;
select * from student order by id;
insert觸發器,會在inserted表中添加一條剛插入的記錄。
# 創建delete類型觸發器
--delete刪除類型觸發器
if (object_id('tgr_classes_delete', 'TR') is not null)
drop trigger tgr_classes_delete
go
create trigger tgr_classes_delete
on classes
for delete --刪除觸發
as
print '備份數據中……';
if (object_id('classesBackup', 'U') is not null)
--存在classesBackup,直接插入數據
insert into classesBackup select name, createDate from deleted;
else
--不存在classesBackup創建再插入
select * into classesBackup from deleted;
print '備份數據成功!';
go
--
--不顯示影響行數
--set nocount on;
delete classes where name = '5班';
--查詢數據
select * from classes;
select * from classesBackup;
delete觸發器會在刪除數據的時候,將剛才刪除的數據保存在deleted表中。
# 創建update類型觸發器
--update更新類型觸發器
if (object_id('tgr_classes_update', 'TR') is not null)
drop trigger tgr_classes_update
go
create trigger tgr_classes_update
on classes
for update
as
declare @oldName varchar(20), @newName varchar(20);
--更新前的數據
select @oldName = name from deleted;
if (exists (select * from student where name like '%'+ @oldName + '%'))
begin
--更新後的數據
select @newName = name from inserted;
update student set name = replace(name, @oldName, @newName) where name like '%'+ @oldName + '%';
print '級聯修改數據成功!';
end
else
print '無需修改student表!';
go
--查詢數據
select * from student order by id;
select * from classes;
update classes set name = '五班' where name = '5班';
update觸發器會在更新數據後,將更新前的數據保存在deleted表中,更新後的數據保存在inserted表中。
6. SQl中怎麼樣創建觸發器
創建觸發器:
Create
Trigger
名稱
On
表名
For
類型
As
Sql語句
希望對你有幫助!
7. sql創建觸發器
創建觸發器用 CREATE TRIGGER CREATE TRIGGER 觸發器名稱 ON 表名 FOR INSERT、UPDATE 或 DELETE AS T-SQL 語句 注意:觸發器名稱是不加引號的。 例子: create trigger jcsj_1 on 表名 for insert as begin update 表名 set 授課門數=授課門數+1 where 教師ID=(select 教師 ID from inserted) end 詳見 http://tech.ddvip.com/2007-01/116783077317261.html
8. SQL中,如何創建一個有條件的觸發器
以 delete 觸發為例:
createtriggertri_delete
ona--將要進行更改的表名
fordelete--給表刪除一條數據的時候觸發
as
declare@aavarchar(10)
select@aa=afromdeleted
if@aa='a'--處理的條件
begin
raiserror('錯誤',16,8)
rollbacktran
end
觸發器效果:刪除表a數據,如果a列為『a』,即阻止刪除,提示『錯誤』
9. sql server2012如何建立觸發器
首先你當然要有一個資料庫了,這里我使用自己創建的資料庫booksDB。
在資料庫booksDB上創建觸發器,右擊觸發器->新建觸發器,打開之後的界面如下所示
6
資料庫的增刪改查類似