MySql - InnoDB - 事务 , Php版

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: (出处:http://www.cnblogs.com/linguanh/)   1,前序   由于要重构APP(社交类) 服务端接口的部分代码,故接触到了 innoDB,以及事务这个词,下面主要是以例子的形式显示它的用法,理论的东西不过多讲述。

(出处:http://www.cnblogs.com/linguanh/)

 

1,前序

  由于要重构APP(社交类) 服务端接口的部分代码,故接触到了 innoDB,以及事务这个词,下面主要是以例子的形式显示它的用法,理论的东西不过多讲述。

 

2,何为事务

  鄙人在编程方面的解释:多条命令操作放在一起处理 , 例如提交的时候一起提交,撤销的时候也是一起撤销,书本对这个词的定义内容很多。

 

3,myisam 与 innoDB  

  它们都是mysql数据库的引擎,我们一般建表默认的是 myisam 引擎,比较:http://www.cnblogs.com/vicenteforever/articles/1613119.html,个人认为,类似于insert、update、delete 这种操作如果涉及多表或单表互联操作的情况,为了避免数据写脏,请使用事务。因为整个过程中若一条错误,便可以回滚到开始时的状态。

 

4,分享个基于php的类

 

 1 <?php
 2 
 3 /**
 4  * Created by PhpStorm.
 5  * User: 林冠宏
 6  * Date: 2016/4/28
 7  * Time: 10:20
 8  */
 9 include "Config.php"; /** 数据库配置信息类,自行完善 */
10 
11 class Sql{
12     public $link    = null;
13     private $config = null;
14     /**
15      * 是否直接开启事务
16      */
17     public function Sql($begin = false){
18         $this->config = new Config();
19         $this->connect();
20         mysql_query("SET AUTOCOMMIT=0",$this->link); /** 设置不自动提交,默认是自动提交 */
21         if($begin){
22             $this->SWBegin();
23         }
24     }
25 
26     public function connect(){
27         $this->link = mysql_connect($this->config->host,$this->config->user,$this->config->pw); /** 连接数据库 */
28         mysql_query("SET NAMES 'utf8'",$this->link); /** 经验总结,使用mysql设置页面编码,最好等链接了,再设置,意思是在连库函数后面使用 */
29 
30         if(!$this->link){
31             exit("connect_dataBase_wrong");
32         }
33         if(!mysql_select_db($this->config->db,$this->link)){
34             exit("select_db_wrong");
35         }
36     }
37 
38     /**
39      * 命令、是否判断行数、出错是否自动启用回滚、链式提交
40      */
41     public function exec($query,$judgeLength=false,$rollBack = false,$isCommit=false){
42         $res = mysql_query($query,$this->link);
43         if($judgeLength){ /** 是否判断行数 */
44             if(mysql_num_rows($res)<=0){
45                 return null;
46             }
47         }else{
48             if(!$res){
49                 if($rollBack) {
50                     $this->rollBack();
51                 }
52                 exit($query); /** 抛出出错的 sql 语句 */
53             }
54         }
55         if($isCommit){
56             return $this;
57         }else{
58             return $res;
59         }
60     }
61 
62     /** 开始事务 */
63     public function SWBegin(){
64         mysql_query("BEGIN",$this->link);
65     }
66 
67     /** 回滚 */
68     public function rollBack(){
69         mysql_query("ROLLBACK",$this->link);
70     }
71 
72     /** 提交事务 */
73     public function commit($getThis=false){
74         mysql_query("COMMIT",$this->link);
75         if($getThis){
76             return $this;
77         }else{
78             return null;
79         }
80     }
81 }
82 
83 ?>

5,例子

 1 <?php
 2 /**
 3  * Created by PhpStorm.
 4  * User: 林冠宏
 5  * Date: 2015/10/24
 6  * Time: 11:23
 7  */
 8 
 9 include "Sql.php";
10 $sql = new Sql();
11 
12 /** 往 aa 表中插入一批数据,注意建aa表的时候要选择 innoDB 引擎 */
13 for($i=0;$i<10;$i++){
14     $temp = $i."k";
15     $query = "insert into aa (a,w) values('$i','$temp')";
16     $sql->exec($query);
17 }
18 
19 /** 下面的注释君请自行开启看效果 */
20 //$sql->rollBack(); /** 回滚的话,上面的所有insert不会被执行 */
21 //$sql->commit();     /** 不commit提交的话,上面的insert也不会被执行 */
22 
23 /** select 操作不用commit也可以直接使用 结果集 */
24 /*
25 $result = $sql->exec("select * from aa");
26 while($row = mysql_fetch_assoc($result)){
27     print($row)."</br>";
28 }
29 */
30 
31 ?>
View Code

 

 

如果您认为这篇文章还不错或者有所收获,您可以通过扫描一下下面的支付宝二维码 打赏我一杯咖啡【物质支持】,也可以点击右下角的【推荐】按钮【精神支持】,因为这两种支持都是我继续写作,分享的最大动力


img_12e3f54d4d0f70f0eb14f20548e3d781.png
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
19天前
|
SQL 关系型数据库 MySQL
轻松入门MySQL:保障数据完整性,MySQL事务在进销存管理系统中的应用(12)
轻松入门MySQL:保障数据完整性,MySQL事务在进销存管理系统中的应用(12)
|
1月前
|
存储 关系型数据库 MySQL
MySQL InnoDB数据存储结构
MySQL InnoDB数据存储结构
|
1月前
|
存储 缓存 关系型数据库
MySQL的varchar水真的太深了——InnoDB记录存储结构
varchar(M) 能存多少个字符,为什么提示最大16383?innodb怎么知道varchar真正有多长?记录为NULL,innodb如何处理?某个列数据占用的字节数非常多怎么办?影响每行实际可用空间的因素有哪些?本篇围绕innodb默认行格式dynamic来说说原理。
829 6
MySQL的varchar水真的太深了——InnoDB记录存储结构
|
12天前
|
存储 关系型数据库 MySQL
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
28 0
|
8天前
|
PHP
web简易开发——通过php与HTML+css+mysql实现用户的登录,注册
web简易开发——通过php与HTML+css+mysql实现用户的登录,注册
|
12天前
|
存储 SQL 关系型数据库
【MySQL实战笔记】03.事务隔离:为什么你改了我还看不见?-02
【4月更文挑战第7天】数据库通过视图实现事务隔离,不同隔离级别如读未提交、读已提交、可重复读和串行化采用不同策略。以可重复读为例,MySQL使用多版本并发控制(MVCC),每个事务有其独立的视图。回滚日志在无更早视图时被删除。长事务可能导致大量存储占用,应避免。事务启动可显式用`begin`或设置`autocommit=0`,但后者可能意外开启长事务。建议使用`autocommit=1`并显式管理事务,若需减少交互,可使用`commit work and chain`。
28 5
|
25天前
|
关系型数据库 MySQL 测试技术
面试-MySQL的四种事务隔离级别
面试-MySQL的四种事务隔离级别
18 0
|
26天前
|
存储 缓存 关系型数据库
MySQL事务的四大特性是如何保证的
在MySQL数据库中还有一种二进制日志,其用来基于时间点的还原及主从复制。从表面上来看其和重做日志非常相似,都是记录了对于数据库操作的日志。但是,从本质上来看有着非常大的不同。
11 1
|
1月前
|
存储 SQL 关系型数据库
[MySQL]事务原理之redo log,undo log
[MySQL]事务原理之redo log,undo log
|
SQL 关系型数据库 MySQL
【mysql】—— 事务
【mysql】—— 事务