标签:insert 触发器 20190422 14311011 TRIGGER SQL XS WHERE SELECT
-- 1 数据库服务
-- 2 触发器
CREATE TRIGGER no_insert
on xs
AFTER INSERT
AS
BEGIN
RAISERROR('XS不让插入数据',1,1);
ROLLBACK TRANSACTION
END
SELECT *
FROM XS WHERE 学号='14311011'
INSERT INTO xs(学号,姓名,总学分)
values('14311011','soar1','20')
EXEC Sp_helptext no_insert -- sys.sp_ -- 触发器的查看内容
-- 触发器的启用和禁用
-- 删除
DROP TRIGGER no_insert
--重命名
EXEC sp_rename no_insert,new_insert;
-- 禁用和启用触发器,语句
ALTER TABLE XS DISABLE TRIGGER new_insert
ALTER TABLE XS ENABLE TRIGGER new_insert
-- INSERT
-- DELETE
SELECT *
FROM XS WHERE 学号='14311011'
--
DELETE FROM XS
WHERE 学号='14311011'; -- 1
CREATE TRIGGER xs_del
ON XS
AFTER DELETE
AS
BEGIN
SELECT 学号 AS '被删除的学生',姓名 FROM deleted
END
-- UPDATE 更新 ,更新为 test
SELECT *
FROM XS WHERE 学号='14311011'
UPDATE XS SET 姓名='soar'
WHERE 学号='14311011'
SELECT LEN('soar.pang')
--
CREATE TRIGGER XS_UPDATE
ON XS
AFTER UPDATE
AS
BEGIN
SELECT 姓名 as '更改后',学号 FROM inserted;
SELECT 姓名 as '更新前',学号 FROM deleted;
END
-- 真的数据库的触发器
CREATE TRIGGER safty
ON DATABASE -- ALL SERVER 表
FOR DROP_TABLE,ALTER_TABLE -- AFTER
AS
BEGIN
PRINT '当前数据库禁止更新删除动作' --并更
ROLLBACK TRANSACTION
END
DROP TABLE Test_2019_02;
-- 表级、服务器、数据库级别
-- 级联
CREATE TRIGGER trigdel
ON XS
AFTER DELETE
AS
BEGIN
DELETE XK WHERE 学号=(SELECT 学号 from deleted)
END
SELECT * FROM XS where 学号='14311002'
SELECT * from xk where 学号='14311002' -- inner join
-- where
DELETE XS WHERE 学号='14311002'
-- 索引
-- 第一个索引 位置
标签:insert,触发器,20190422,14311011,TRIGGER,SQL,XS,WHERE,SELECT
来源: https://www.cnblogs.com/Soar-Pang/p/10748757.html
本站声明:
1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。