来自 新葡亰数据库 2019-11-10 02:38 的文章
当前位置: 澳门新葡亰app > 新葡亰数据库 > 正文

并可以将其当作表来使用

一、视图

视图是贰个虚构表(非真实存在卡塔 尔(英语:State of Qatar),其本质是【依据SQL语句获取动态的数据集,并为其取名】,客商接收时只需使用【名称】就能够拿到结果集,并能够将其当做表来利用。

图片 1图片 2

 1 SELECT
 2     *
 3 FROM
 4     (
 5         SELECT
 6             nid,
 7             NAME
 8         FROM
 9             tb1
10         WHERE
11             nid > 2
12     ) AS A
13 WHERE
14     A. NAME > 'alex';

有时表寻觅

1、创制视图

图片 3图片 4

1 --格式:CREATE VIEW 视图名称 AS  SQL语句
2 CREATE VIEW v1 AS 
3 SELET nid, 
4     name
5 FROM
6     A
7 WHERE
8     nid > 4

View Code

2、删除视图

图片 5图片 6

1 --格式:DROP VIEW 视图名称
2 
3 DROP VIEW v1

View Code

3、校珍视图

图片 7图片 8

 1 -- 格式:ALTER VIEW 视图名称 AS SQL语句
 2 
 3 ALTER VIEW v1 AS
 4 SELET A.nid,
 5     B. NAME
 6 FROM
 7     A
 8 LEFT JOIN B ON A.id = B.nid
 9 LEFT JOIN C ON A.id = C.nid
10 WHERE
11     A.id > 2
12 AND C.nid < 5

View Code

4、使用视图

选用视图时,将其当做表实行操作就可以,由于视图是虚构表,所以无法利用其对实际表张开创办、更新和删除操作,仅能做询问用。

1 select * from v1

二、触发器

对有些表打开【增/删/改】操作的左右假如指望触发有个别特定的行为时,能够运用触发器,触发器用于定制客户对表的行开展【增/删/改】前后的行事。

1、创立基本语法

图片 9图片 10

 1 # 插入前
 2 CREATE TRIGGER tri_before_insert_tb1 BEFORE INSERT ON tb1 FOR EACH ROW
 3 BEGIN
 4     ...
 5 END
 6 
 7 # 插入后
 8 CREATE TRIGGER tri_after_insert_tb1 AFTER INSERT ON tb1 FOR EACH ROW
 9 BEGIN
10     ...
11 END
12 
13 # 删除前
14 CREATE TRIGGER tri_before_delete_tb1 BEFORE DELETE ON tb1 FOR EACH ROW
15 BEGIN
16     ...
17 END
18 
19 # 删除后
20 CREATE TRIGGER tri_after_delete_tb1 AFTER DELETE ON tb1 FOR EACH ROW
21 BEGIN
22     ...
23 END
24 
25 # 更新前
26 CREATE TRIGGER tri_before_update_tb1 BEFORE UPDATE ON tb1 FOR EACH ROW
27 BEGIN
28     ...
29 END
30 
31 # 更新后
32 CREATE TRIGGER tri_after_update_tb1 AFTER UPDATE ON tb1 FOR EACH ROW
33 BEGIN
34     ...
35 END

View Code

图片 11图片 12

 1 delimiter //
 2 CREATE TRIGGER tri_before_insert_tb1 BEFORE INSERT ON tb1 FOR EACH ROW
 3 BEGIN
 4 
 5 IF NEW. NAME == 'alex' THEN
 6     INSERT INTO tb2 (NAME)
 7 VALUES
 8     ('aa')
 9 END
10 END//
11 delimiter ;

插入前触发器

图片 13图片 14

 1 delimiter //
 2 CREATE TRIGGER tri_after_insert_tb1 AFTER INSERT ON tb1 FOR EACH ROW
 3 BEGIN
 4     IF NEW. num = 666 THEN
 5         INSERT INTO tb2 (NAME)
 6         VALUES
 7             ('666'),
 8             ('666') ;
 9     ELSEIF NEW. num = 555 THEN
10         INSERT INTO tb2 (NAME)
11         VALUES
12             ('555'),
13             ('555') ;
14     END IF;
15 END//
16 delimiter ;

插入后触发器

特意的:NEW表示将在插入的多少行,OLD代表将在删除的数据行。

2、删除触发器

1 DROP TRIGGER tri_after_insert_tb1;

3、使用触发器

触发器不恐怕由客商直接调用,而是由于对表的【增/删/改】操作被动引发的。

1 insert into tb1(num) values(666)

 

本文由澳门新葡亰app发布于新葡亰数据库,转载请注明出处:并可以将其当作表来使用

关键词: