mysql触发器验证支付_MySQL 触发器 目录

本文详细介绍了MySQL触发器的使用方法,包括insert、update、delete触发器的创建及应用,并深入探讨了触发器中new和old虚拟表的作用。此外,还讲解了不同类型的索引,如普通索引、唯一索引、主键索引和全文索引等的特点及应用场景。

MySQL 触发器 索引

博文目录

触发器

索引

触发器是MySQL响应insert,update,delete语句时自动执行的一条SQL语句,只有表支持触发器,视图不支持。

触发器需要的信息

唯一的触发器名称(一个表中唯一)

触发器关联的表

触发器应该响应的事件(insert?update?delete?)

触发器何时执行(处理之前或处理之后)

一个表的一个事件最多只能有两个触发器,所以一个表最多有6个触发器

如果响应之前的触发器执行失败,响应则不会执行;响应之前的触发器或响应执行失败,响应之后的触发器不会执行

insert触发器

create trigger tr_insert_tableA after insert on t_tableA for each row insert into t_tableB(val) values (new.val);

欢迎大家阅读《MySQL 触发器 目录》,跪求各位点评,by 搞代码

在insert触发器内,可引用一个名为new的虚拟表,访问被插入的行

在before insert触发器中,new中的值也可以被更新(new可以取到插入的值)

对于自动增长的列,new在insert执行之前的值为0,在执行之后是新的自动生成的值

获取刚刚插入的自动生成的主键值

create trigger t_insert_pk_tableA after insert on t_tableA for each row select new.id into @id;

insert into t_tableA(val) values("abc"); select @id;

delete触发器

delimiter // create trigger t_delete_tableA after delete on t_tableA for each row begin insert into t_tableB(val) values(old.val); end // delimiter ; delete from t_tableA where id=2;

在delete触发器代码中,可以引用了一个old的虚拟表,访问被删除的行

old表中值全是只读的,不能更新

update触发器

将A表中修改后的名字都改为大写

delimiter // create trigger t_update_tableA before update on t_tableA for each row begin set new.val=upper(new.val); end // delimiter ; update t_tableA set val='xyz' where id=1; select * from t_tableA;

在update触发器代码中,可以引用一个名为old的虚拟表访问以前的值,引用new表访问新的值

在before update触发器中,new中值允许被更新

old表中的值是只读的,不能更改

删除触发器

drop trigger tr_insert_tableA;

索引

索引是优化数据库查询速度的重要途径

索引类型

普通索引:最基本的索引,没有唯一性之类的限制

create index valindex on t_tableA(val(20)); create index products_index on products(prod_name(25),prod_price);

唯一索引:所有的索引列只能出现一次,保持唯一性

create unique index valindex2 on t_tableB(val(20));

主键索引:主键索引是一种特殊的唯一索引,在主键建立时自动创建

全文索引:全文所以可以在varchar或text类型上创建

索引的缺点

虽然索引大大提高了查询速度,但会降低更新表的速度,比如对表的insert,update,delete操作,因为更新表时,MySQL不仅仅要保存数据,还要保存索引文件

建立索引会占用磁盘空间。如果在一个大表上创建了多种索引组合,索引文件会膨胀的很快。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值