事务与存储过程

事务管理

  事务的概念

    谓的事务就是针对数据库的一组操作,它可以由一条或多条SQL语句组成,同一个事务的操作具备同步的特点,即事务中的语句要么都执行,要么都不执行。

  事务的使用

    开启事务START TRANSACTION;

    执行SQL语句

    提交事务COMMIT;

    取消事务(回滚)

  事务的提交

    事务中的操作语句都需要使用COMMIT语句手动提交,只有事务提交后其中的操作才会生效。

  事务的回滚

    如果不想提交当前事务,可使用ROLLBACK语句取消当前事务。

    ROLLBACK语句只能针对未提交的事务执行回滚操作,已提交的事务是不能回滚的。

  事务的隔离级别

    REPEATABLE READ(可重复读)

    READ UNCOMMITTED(读未提交)

    READ COMMITTED(读提交)

    SERIALIZABLE(可串行化)

事务的定义特性

  原子性

  原子性是指一个事务必须被视为一个不可分割的最小工作单元,只有事务中所有的数据库操作都执行成功,才算整个事务执行成功

  一致性

   一致性是指事务将数据库从一种状态转变为下一种一致的状态。

  隔离性

   隔离性还可以称为并发控制、可串行化、锁等,当多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离。  

  持久性

  事务一旦提交,其所做的修改就会永久保存到数据库中,即使数据库发生故障也不应该对其有任何影响。

  事务的持久性不能做到100%的持久,只能从事务本身的角度来保证永久性,而一些外部原因导致数据库发生故障,如硬盘损坏,那么所有提交的数据可能都会丢失。

存储过程的创建

  什么是存储过程

    存储过程就是一条或多条SQL语句的集合,当对数据库进行一系列复杂操作时,存储过程可以将这些复杂操作封装成一个代码块,以便重复使用,大大减少数据库开发人员的工作量。

  创建存储过程

    CREATE PROCEDURE sp_name([proc_parameter])

    [characteristics…]routine_body

    CREATE PROCEDURE:为用来创建存储过程的关键字。

    sp_name:为存储过程的名称。

    proc_parameter:为指定存储过程的参数列表。

    characteristics:用于指定存储过程的特性。

  变量的使用

    定义

      在MySQL中,变量可以在子程序中声明,用于保存数据处理过程中的值,这些变量的作用范围在BEGIN…END程序中。

      DECLARE var_name[,varname]…date_type[DEFAULT value];

      var_name:为局部变量的名称。

      DEFAULT value:子句给变量提供一个默认值,该值可以被声明为一个常数或一个表达式。如果没有DEFAULT子句,变量的初始值为NULL。

    使用SET语句为变量赋值

      SET var_name =

      expr[,var_name = expr]…;

    使用SELECT…INTO为一个或多个变量赋值

      SELECT col_name[…]

      INTO var_name[…] table_expr;

  定义条件和处理程序

    定义条件是指事先定义程序执行过程中遇到的问题

      DECLARE condition_name CONDITION FOR [condition_type];

      // condition_type的两种形式:

      [condition_type]:

      SQLSTATE[VALUE] sqlstate_value|mysql_error_code

    处理程序定义了在程序执行过程中遇到问题时应当采取的处理方式,并且保证存储过程在遇到警告或错误时能继续执行处理过程使用DECLARE语句定义

      DECLARE handler_type HANDLER FOR condition_value[,…] sp_statement

      handler_type:

      CONTINUE|EXIT|UNDO

      condition_value:

      |condition_name

      |SQLWARNING

      |NOT FOUND

      |SQLEXCEPTION

      |mysql_error_code

      handler_type:为错误处理方式,参数取值

      有3个:CONTINUE、EXIT和UNDO。

     CONTINUE:表示遇到错误不处理,继续执行;

     EXIT:遇到错误马上退出。

     UNDO:表示遇到错误后撤回之前的操作,MySQL中暂时不支持这样的操作。sp_statement:参数为程序语句段,表示在遇到定义的错误时,需要执行的存储过程。

      condition_value:表示错误类型。

  光标的使用

    在编写存储过程时,查询语句可能会返回多条记录,如果数据量非常大,则需要使用光标来逐条读取查询结果集中的记录。光标是一种用于轻松处理多行数据的机制。

    声明

      语法:DECLARE cursor_name CURSOR FOR select_statement

      示例:DECLARE cursor_student CURSOR FOR select s_name,s_gender FROM student;

    使用

      语法:OPEN cursor_name FETCH cursor_name INTO var_name[,var_name]…

      示例:FETCH cursor_student INTO s_name, s_gender;

    关闭

      CLOSE cursor_name

流程控制的使用

  存储过程中的流程控制语句用于将多个SQL语句划分或组合成符合业务逻辑的代码块,MySQL中的流程控制语句有7个

  1、 IF语句

    语法格式如下:

    IF expr_condition THEN statement_list

    [ELSEIF expr_condition THEN statement_list]

    [ELSE statement_list]

    END IF

  2、CASE语句

    语法格式如下:

    CASE case_expr

WHEN when_value THEN statement_list

[WHEN when_value THEN statement_list]…

[ELSE statement_list]

    END CASE

  3、 LOOP语句

    语法格式如下:

    [loop_label:]LOOP

    statement_list

    END LOOP [loop_label]

4、LEAVE语句

    语法格式如下:

    LEAVE lable

  5、ITERATE语句

    语法格式如下:

    ITERATE lable

6、REPEAT语句

    语法格式如下:

    [repeat_lable:] REPEAT

    statement_list

    UNTIL expr_condition

    END REPEAT[repeat_lable]

  7、WHILE语句

    语法格式如下:

    [[while_lable:] WHILE expr_condition DO

    Statement_list

    END WHILE [while_lable]

存储过程的使用

  调用存储过程

    CALL sp_name([parameter[,…]])

    CALL:为调用存储过程的关键字。

    sp_name:为存储过程的名称。

    Parameter:为存储过程的参数。

  查看存储过程

    1、使用SHOW STATUS语句

      CALL sp_name([parameter[,…]])

    2、使用SHOW CREATE语句

      SHOW CREATE{PROCEDURE|FUNCTION} sp_name

    3、information_schema.Routines表中查看

      SELECT * FROM  information_schema.Routines

      WHERE ROUTINE_NAME='CountProc1'

      AND ROUTINE_TYPE='PROCEDURE'\G

  修改存储过程

    ALTER {PROCEDURE|FUNCTION} sp_name[characteristic…]

    sp_name:表示存储过程或函数的名称。characteristic:表示要修改存储过程的哪个部分, characteristic 的取值分为8部分。

  删除存储过程

    DROP{ PROCEDURE|FUNCTION }[IF EXISTS] sp_name

    综合案例--存储过程应用

MySQL<事务与存储过程>的更多相关文章

  1. Hadoop 中利用 mapreduce 读写 mysql 数据

    Hadoop 中利用 mapreduce 读写 mysql 数据   有时候我们在项目中会遇到输入结果集很大,但是输出结果很小,比如一些 pv.uv 数据,然后为了实时查询的需求,或者一些 OLAP ...

  2. mysql每秒最多能插入多少条数据 ? 死磕性能压测

    前段时间搞优化,最后瓶颈发现都在数据库单点上. 问DBA,给我的写入答案是在1W(机械硬盘)左右. 联想起前几天infoQ上一篇文章说他们最好的硬件写入速度在2W后也无法提高(SSD硬盘) 但这东西感 ...

  3. LINUX篇,设置MYSQL远程访问实用版

    每次设置root和远程访问都容易出现问题, 总结了个通用方法, 关键在于实用 step1: # mysql -u root mysql mysql> Grant all privileges o ...

  4. nodejs进阶(6)—连接MySQL数据库

    1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...

  5. MySQL高级知识- MySQL的架构介绍

    [TOC] 1.MySQL 简介 概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而 ...

  6. 闰秒导致MySQL服务器的CPU sys过高

    今天,有个哥们碰到一个问题,他有一个从库,只要是启动MySQL,CPU使用率就非常高,其中sys占比也比较高,具体可见下图. 注意:他的生产环境是物理机,单个CPU,4个Core. 于是,他抓取了CP ...

  7. 我的MYSQL学习心得(一) 简单语法

    我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...

  8. Entity Framework Core 实现MySQL 的TimeStamp/RowVersion 并发控制

    将通用的序列号生成器库 从SQL Server迁移到Mysql 遇到的一个问题,就是TimeStamp/RowVersion并发控制类型在非Microsoft SQL Server数据库中的实现.SQ ...

  9. Docker笔记一:基于Docker容器构建并运行 nginx + php + mysql ( mariadb ) 服务环境

    首先为什么要自己编写Dockerfile来构建 nginx.php.mariadb这三个镜像呢?一是希望更深入了解Dockerfile的使用,也就能初步了解docker镜像是如何被构建的:二是希望将来 ...

  10. 当忘记mysql数据库密码时如何进行修改

    因为长时间没有使用数据库了,或者把密码改完之后就忘了数据库密码,不能正常进入数据库,也无法修改密码,有一个简单的常用修改密码方式: 1.首先找到和打开mysql.exe和mysqld.exe所在的文件 ...

随机推荐

  1. 李洪强iOS之集成极光推送二iOS 证书 设置指南

    李洪强iOS之集成极光推送二iOS 证书 设置指南 创建应用程序ID 登陆 iOS Dev Center 选择进入iOS Provisioning Portal. 在 iOS Provisioning ...

  2. 一些有用的Sql语句

    1.插入数据后,返回插入的Id ')

  3. 路由器的LAN口和WAN口有什么区别

    路由器WAN接口连接的是外网,拉进来的网线就是接这个接口. 路由器LAN接口是连接的内网,家里如有几台设备需要拉线上网都是从这个接口接出去的.   路由器(Router,又称路径器)是一种计算机网络设 ...

  4. 六步破解win2008R2登录密码

    防火墙没有开启,win2008R被当成矿机,只好重新破解密码进去解决问题,试了好多方法,下列方法绝对实用简单. 破解2008登录密码的方法: 1.进入PE2.找到文件:windows\system32 ...

  5. linux中mysql表名默认区分大小写导致表找不到的问题

    天将window的项目迁移到linux上面,然后登录时一直报用户表找不到的错误信息. 检查发现数据库中的表名是m_user, 后来才想起来是大小写问题, 找到问题原因,解决方案如下: 修改/etc/m ...

  6. 【SpringMVC笔记】第三课 处理器映射器+处理器适配器

    第二课的例子中,在springmvc.xml中配置使用了第一种处理器映射器和处理器适配器,如下所示. <!-- 配置第一种处理器映射器 BeanNameUrlHandlerMapping --& ...

  7. Jquery实现仿腾讯微薄的广播发表

    前言: 由于这几天在学习Jquery的一些知识,比以前的感觉就是Jquery太强大了,很多很简单的功能以前在JavaScript要写几十行的代码而在Jquery中只用几行代码就搞定了,所以我决定好好学 ...

  8. 每个Web开发者都应该知道的关于URL编码的知识

    本文首先阐述了人们关于统一资源定位符(URL)编码的普遍的误读,其后通过阐明HTTP场景下的URL encoding 来引出我们经常遇到的问题及其解决方案.本文并不特定于某类编程语言,我们在Java环 ...

  9. 数据库之“on”“where”区别

    数据库在通过连接两张或者多张表返回记录时,都会生成一张中间的临时表,然后再将这张临时表返回给用户 在使用inner join(内连接)没有区别,但是 在使用left jion时,on和where条件的 ...

  10. java笔记知识点总结

    1.switch case default 语句 : switch case 语句是一个条件选择语句,找到相同的case值做为入口,执行后面的程序:若所有的case都不满足,则找default入口:若 ...