首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL 之视图、 触发器事务、存储

本文内容: 视图 触发器 事务 存储过程 内置函数 流程控制 索引 ----------------------------------------------...drop trigger tri_after_insert_cmd; 三、事务 简言之:多个sql语句执行生效的状态必须同步进行 也就是说开启事务后,事务里的所有sql语句,要么全部生效成功...insert into user(name,balance) values ('李逍遥',1000), ('酒剑仙',1000), ('赵灵儿',1000); -- 修改数据之前开启事务操作...函数不要写sql语句(否则会报错),函数仅仅只是一个功能,是一个在sql中被应用的功能 若要想在begin...end...写sql,请用存储过程 MySQL中提供了许多内置函数,例如:...由于数据的IO操作导致MySQL的存储引擎有一套用于快速找到记录的一种数据结构,这个结构称之为--索引,在MySQL也叫‘键’ primary key unique key index key  注意

88520
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL触发器的使用

    触发器触发器的使用场景以及相应版本: 触发器可以使用的MySQL版本: 版本:MySQL5以上 使用场景例子: 每当增加一个顾客到某个数据库表时,都检查其电话号码格式是否正确,州的缩写是否为大写 每当订购一个产品时...可以引用一个名为NEW的虚拟表,访问被插入的行; 在before insert触发器,NEW的值也可以被更新(允许更改被插入的值) 对于AUTO_INCREMENT列,NEW在insert执行之前包含...: 在update触发器的代码,可以引用一个名为OLD的虚拟表访问以前的值,即:update未执行前的值,还可以引用一个名为NEW的虚拟表访问新更新的值; 在before update触发器,NEW...: 在DELETE触发器在delete语句执行之前或之后执行: 在delete触发器代码内,可以引用OLD的虚拟表,访问被删除的行; OLD的值全部都是只读,不能更新 例子: 使用old保存将要被删除的行到一个存档表...“Not allowed to return a result set from a trigger” 原因:因为从MySQL5以后不支持触发器返回结果集 解决方法:在后面语句后面添加 into @变量名

    3.3K10

    MySQL 事务详解

    http://blog.csdn.net/qh_java/article/details/14045765 1、事务的概念 2、在mysql哪些存储引擎(表类型)支持事务哪些不支持 3、事务的四个属性...4、mysql事务的创建与存在周期 5、mysql行为 6、事务的孤立性和性能 7、mysql的伪事务 一、事务的概念    事务由单独单元的一个或多个SQL语句组成,在这个单元,每个...二、MySQL 的存储引擎以及支持事务,和不支持事务的存储引擎    1、存储引擎的概念:在mysql的数据用各种不同的技术存储在文件(或内存)。...2、 set   autocommit =0;  //关闭自动提交 3、 set   autocommit =1;  //开启自动提交  六、事务的孤立性(隔离性) 1、在多用户的时候使用孤立性级别是很重要的...七、伪事务(锁定) 1、在MySQL根据不同的需求,提供了很多存储引擎,但是有的存储引擎不支持事务,对于这种情况,可以使用表锁定来代替事务

    1K10

    MySQL事务事务隔离级别

    CSDN话题挑战赛第2期 参赛话题:学习笔记 事务(Transaction) 什么是事务? 一个事务是一个完整的业务逻辑单元,不可再分。...对于数据库来说事务保证批量的DML要么全成功,要么全失败。 事务的四个特征ACID 原子性(Atomicity) 整个事务的所有操作,必须作为一个单元全部完成(或全部取消)。...持久性(durability) 持久性是指一个事务一旦被提交,它对数据库数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响。 事务相关的语句只有:DML语句。...开启事务机制: 执行insert语句–>insert…(这个执行成功之后,把这个执行记录到数据库的操作历史当中,并不会向文件中保存一条数据,不会真正的修改硬盘上的数据。)...需要事务排队。 Oracle数据库默认的隔离级别是二挡起步:读已提交。(read committed) Mysql 数据库默认的隔离级别是三档起步:可重复读(repeatable read)。

    76920

    mysql触发器

    前言 近期遇到需要写触发器的需求,需要将A表数据修改的信息,添加到B表,之前比较少写,记录一下学习到的一些知识点 触发器的好处 使用触发器,把更改(如果需要,甚至还有之前和之后的状态)记录到另一个表非常容易...触发器关键字 在触发器我们经常会用到NEW和OLD这两个关键字下面来分别了解一下 NEW是指刚刚插入到数据库的数据表的一个域,。...触发器不支持CALL语句。...但是对这部分内容点比较陌生,后面通过触发器关键字解决了这个问题,但是还是需要扩展一下binlog相关的知识点 MySQL的二进制日志binlog可以说是MySQL最重要的日志,它记录了所有的DDL和DML...语句(除了数据查询语句select),以事件形式记录,还包含语句所执行的消耗的时间,MySQL的二进制日志是事务安全型的

    6.7K30

    MySQL触发器

    这样一来,我们就必须把这两个关联的操作步骤写到程序里面,而且要用 事务 包裹起来,确保这两个操 作成为一个 原子操作 ,要么全部执行,要么全部不执行。...触发器概述  MySQL从 5 . 0 . 2 版本开始支持触发器MySQL触发器和存储过程一样,都是嵌入到MySQL服务器的一 段程序。...当对数据表的数据执行插入、更新和删除操作,需要自动执行一些数据库逻辑时,可以使用触发器来 实现。...因为触发器存储在数据库,并且由事件驱动,这就意味着触发器有可能 不受应用层的控制 。这对系统维护是非常有挑战的。 比如,创建触发器用于修改会员储值操作。...如果触发器的操作出了问题,会导致会员储值金额更新失败。我用下面的代码演示一下  结果显示,系统提示错误,字段“aa”不存在。 这是因为,触发器的数据插入操作多了一个字段,系统提示错误。

    3.2K20

    MySQL进阶|MySQL事务(二)

    引言 上一个章节说了什么是事务,在MySQL数据库如何查询事务,以及哪些存储引擎支持事务。这一章节来说说事务的隔离。...上一篇传送:MySQL进阶|MySQL事务(一) 1.1 隔离的设计 事务隔离是数据库处理的基础之一。...隔离级别所能解决的问题如下: 1.3 事务MySQL语句中使用 「开启事务」 BEGIN 或 START TRANSACTION ; 「提交事务」 COMMIT 也可以使用 COMMIT WORK...回滚会结束用户的事务,并撤销正在进行的所有未提交的修改; 「创建保存点」 SAVEPOINT identifier,SAVEPOINT 允许在事务创建一个保存点,一个事务可以有多个 SAVEPOINT...开启事务、回滚事务 mysql> START TRANSACTION; Query OK, 0 rows affected (0.00 sec) mysql> mysql> show tables;

    13110

    MySQL触发器

    MySQL触发器 1.1. 定义 1.2. 创建触发器 1.2.1. 创建一行执行语句的触发器 1.2.2. 创建多行执行语句的触发器 1.3. 查看触发器 1.3.1....注意 MySQL触发器 定义 MySQL触发器和存储过程一样,都是嵌入到MysQL的一段程序,不过触发器不要调用,而是由事件触发的,这些事件包括insert,update,delete语句,如果定义了触发程序...trigger_event:触发事件,取值为insert,update,delete insert :比如Mysql的insert和replace语句就会触发这个事件 update:更新某一行的数据会激发这个事件...: 删除指定数据库触发器 db :数据库的名字 trigger_name :触发器的名字 触发器执行的顺序 我们建立的数据库一般都是InnoDB数据库,其上建立的表是事务性表,也就是事务安全的。...这时,若SQL语句或触发器执行失败,MySQL 会回滚事务,有: 如果 BEFORE 触发器执行失败,SQL 无法正确执行。 SQL 执行失败时,AFTER 型触发器不会触发。

    5K20

    MySQL触发器

    大家好,又见面了,我是全栈君 MySQL在5.0.2版本以上开始支持触发器触发器是有某些带有命令的时间来触发某些操作,这些事件包括insert语句、delete语句、update语句等。...1、创建mysql触发器: (1)创建具有单个执行语句的触发器 create trigger 触发器名称 before | after触发事件 on 表名 for each row 执行语句 before...insert on studentinfo for each row insert into timelog(savetime) values(now()); // 当用户向studentinfo表insert...之前,数据库会自动向timelog插入当前操作的时间 更多:http://hovertree.com/menu/mysql/ (2)创建具有多个执行语句的触发器 create trigger 触发器名称...:是数据库中用于记录触发器信息的数据表; TRIGGER_NAME:用于指定要查看的触发器名称 3、删除触发器 droptrigger 触发器名称; 发布者:全栈程序员栈长,转载请注明出处:https

    3.9K20

    Mysql触发器

    数据库除了需要定时完成一些任务外,有时我们也想在某些表数据变化时自动执行些操作,这就要用到触发器了 基本语法 -- 删除已有同名触发器 DROP TRIGGER IF EXISTS trigger_name...NEW.groupid and subjectid=NEW.subjectid ORDER BY examtime desc limit 0,1); END; $$ delimiter ; 定义变量 mysql...PREPARE stmt FROM @v_sql; EXECUTE stmt; DEALLOCATE PREPARE stmt; NEW 与 OLD 上述示例中使用了 NEW 关键字 MySQL...定义了 NEW 和 OLD,用来表示触发器的所在表,触发了触发器的那一行数据。...具体: 在 INSERT 型触发器,NEW 用来表示将要(BEFORE)或已经(AFTER)插入的新数据; 在 UPDATE 型触发器,OLD 用来表示将要或已经被修改的原数据,NEW 用来表示将要或已经修改为的新数据

    4.5K30

    聊聊MySQL事务

    聊聊MySQL事务 说起事务,大家可能都有自己的理解,事务的本质其实就是一连串的sql操作,要么全部成功,要么全部失败。...持久性是说事务再进行的过程,状态一旦提交,不会因为其他原因而回退,状态结果将永久保留。...初次之外,在MySQL事务具有四种隔离级别,分别是Read Uncommitted,Reas Committed,Repeatable Read以及Serializable.为什么这么称呼,有什么区别...事务开启之前,我们查询到表里面的name是"郭靖",而在事务执行的过程,由于在session B上的操作,导致name里面的值变为了"yeyz",也就是我们读到了一条脏数据,而这条脏数据,在session...03 幻读 幻读的概念是如果一个事务根据某些条件查询出来一些记录,然后另外一个事务向表插入了一些符合这些条件的记录,那么原先的事务再次查询这个条件的时候,就能读出来一些其他的额外的记录。

    85120

    MySQL进阶|MySQL事务(一)

    文章目录 数据库事务 MySQL的存储引擎 InnoDB存储引擎架构 什么是事务 事务的状态 总结 数据库事务 MySQL 事务主要用于处理操作量大,复杂度高的数据。...那么在MySQL数据库,我们如何查看存储引擎是否支持事务呢?下面我就从我实验机器上的MySQL来一探究竟。...「实验环境」 MySQL 社区版, 8.0.1 MySQL的存储引擎 在MySQL,我们很容易查看存储引擎是否支持事务操作,也可以看到其他的存储引擎是否支持事务。...什么是事务 在百度百科是这样子定义事务事务(Transaction),一般是指要做的或所做的事情。在计算机术语是指访问并可能更新数据库各种数据项的一个程序执行单元(unit)。...事务的状态 在MySQL数据库事务有5种状态,他们分别是活动状态、部分提交状态、失败状态、提交状态、中止状态 。 1)活动状态:事务在执行时的状态叫活动状态。

    15710
    领券