mysql触发器支持视图_MySQL触发器视图

MySQL触发器

触发器(trigger):MySQL包含对触发器的支持。触发器是一种与表操作有关的数据库对象,当触发器所在表上出现指定事件时,将调用该对象,即

表的操作事件触发表上的触发器的执行。 即监视某种情况,并触发某种操作。

触发器创建语法四要素:

1.监视地点(table) 2.监视事件(insert/update/delete) 3.触发时间(after/before) 4.触发事件(insert/update/delete)

创建触发器

语法:

create trigger triggerName

after/before insert/update/delete on 表名

for each row #这句话在mysql是固定的

begin

sql语句;

end;

删除触发器

drop trigger 触发器名称;

查看触发器

SHOW TRIGGERS from 库名

触发器的执行顺序

我们建立的数据库一般都是 InnoDB 数据库,其上建立的表是事务性表,也就是事务安全的。这时,若SQL语句或触发器执行失败,MySQL 会回滚

事务,有:

①如果 BEFORE 触发器执行失败,SQL 无法正确执行。

②SQL 执行失败时,AFTER 型触发器不会触发。

③AFTER 类型的触发器执行失败,SQL 会回滚

视图

视图是虚拟表,本身不存储数据,而是按照指定的方式进行查询。

使用场合

权限控制的时候,不希望用户访问表中某些含敏感信息的列,比如salary...

关键信息来源于多个复杂关联表,可以创建视图提取我们需要的信息,简化操作;

视图的作用

方便操作,特别是查询操作,减少复杂的SQL语句,增强可读性;

更加安全,数据库授权命令不能限定到特定行和特定列,但是通过合理创建视图,可以把权限限定到行列级别;

使用场合

视图的使用方法

108855_0.png

108855_1.png

108855_2.png

这时,当我们想要查询课程相关信息的时候,需要这样写一条长长的SQL语句,如下:

SELECT * from students

LEFT JOIN students_study on students.id = students_study.students_id

LEFT JOIN studyname on students_study .students_id = studyname.id

where students.id = 1

但是我们可以通过视图简化操作,例如我们创建视图view_user_course如下:

CREATE view student_study as

(students.name,students.id,studyname from students

LEFT JOIN students_study on students.id = students_study.students_id

LEFT JOIN studyname on students_study.students_id = studyname.id)

进行视图查询

SELECT * from 视图名称

视图与表是一对一关系情况:

如果没有其它约束(如视图中没有的字段,在基本表中是必填字段情况),是可以进行增删改数据操作;

进行增删改操作如下,操作成功(注意students表中的其它字段要允许为空,否则操作失败):

INSERT INTO student_study (name, age)

VALUES

('test1', 'test1');

DELETE

FROM

student_study

WHEREname = 'test1';

UPDATE

student_study

SET name = 'updateuser'WHEREid = 1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值