最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL触发器目录

来源:动视网 责编:小采 时间:2020-11-09 13:59:39
文档

MySQL触发器目录

MySQL触发器目录:MySQL 触发器 索引 MySQL 触发器 索引 博文目录 触发器 索引 触发器是MySQL响应insert,update,delete语句时自动执行的一条SQL语句,只有表支持触发器,视图不支持。 触发器需要的信息 唯一的触发器名称(一个表中唯一) 触发器关联的表 触发器应该响应
推荐度:
导读MySQL触发器目录:MySQL 触发器 索引 MySQL 触发器 索引 博文目录 触发器 索引 触发器是MySQL响应insert,update,delete语句时自动执行的一条SQL语句,只有表支持触发器,视图不支持。 触发器需要的信息 唯一的触发器名称(一个表中唯一) 触发器关联的表 触发器应该响应


MySQL 触发器 索引 MySQL 触发器 索引 ? 博文目录 ?触发器 索引 ? 触发器是MySQL响应insert,update,delete语句时自动执行的一条SQL语句,只有表支持触发器,视图不支持。 触发器需要的信息 唯一的触发器名称(一个表中唯一) 触发器关联的表 触发器应该响应的

MySQL 触发器 索引

MySQL 触发器 索引

?

博文目录

  1. ?触发器
  2. 索引

?

触发器是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);

    在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不仅仅要保存数据,还要保存索引文件
  • 建立索引会占用磁盘空间。如果在一个大表上创建了多种索引组合,索引文件会膨胀的很快。
  • 文档

    MySQL触发器目录

    MySQL触发器目录:MySQL 触发器 索引 MySQL 触发器 索引 博文目录 触发器 索引 触发器是MySQL响应insert,update,delete语句时自动执行的一条SQL语句,只有表支持触发器,视图不支持。 触发器需要的信息 唯一的触发器名称(一个表中唯一) 触发器关联的表 触发器应该响应
    推荐度:
    标签: 目录 博文 触发器
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top