当前位置:  数据库>mysql

MySQL事务处理与应用简析

    来源: 互联网  发布时间:2014-10-15

    本文导语:  事务处理在各种管理系统中都有着广泛的应用,比如人员管理系统,很多同步数据库操作大都需要用到事务处理。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,...

事务处理在各种管理系统中都有着广泛的应用,比如人员管理系统,很多同步数据库操作大都需要用到事务处理。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!
删除的SQL语句
delete from userinfo where ~~~
delete from mail where ~~
delete from article where~~
~~
如果没有事务处理,在你删除的过程中,假设出错了,只执行了第一句,那么其后果是难以想象的!
但用事务处理。如果删除出错,你只要rollback就可以取消删除操作(其实是只要你没有commit你就没有确实的执行该删除操作)
一般来说,在商务级的应用中,都必须考虑事务处理的!
查看inodb信息
shell> /usr/local/mysql -u root -p
mysql> show variables like "have_%"
系统会提示:
+------------------+-------+
| Variable_name     | Value |
+------------------+-------+
| have_bdb   | YES    |
| have_crypt | YES    |
| have_innodb| YES    |
| have_isam  | YES    |
| have_raid  | YES    |
| have_symlink      | YES    |
| have_openssl      | NO     |
| have_query_cache | YES    |
+------------------+-------+
8 rows in set (0.05 sec)
如果是这样的,那么我们就可以创建一张支持事务处理的表来试试了。
MYSQL的事务处理功能!
一直以来我都以为MYSQL不支持事务处理,所以在处理多个数据表的数据时,一直都很麻烦(我是不得不将其写入文本文件,在系统重新加载得时候才写入数据库以防出错)~今天发现MYSQL数据库从4.1就开始支持事务功能,据说5.0将引入存储过程^_^
先简单介绍一下事务吧!事务是DBMS得执行单位。它由有限得数据库操作序列组成得。但不是任意得数据库操作序列都能成为事务。一般来说,事务是必须满足4个条件(ACID)
原子性(Autmic):事务在执行性,要做到“要么不做,要么全做!”,就是说不允许事务部分得执行。即使因为故障而使事务不能完成,在rollback时也要消除对数据库得影响!
一致性(Consistency):事务得操作应该使使数据库从一个一致状态转变倒另一个一致得状态!就拿网上购物来说吧,你只有即让商品出库,又让商品进入顾客得购物篮才能构成事务!
隔离性(Isolation):如果多个事务并发执行,应象各个事务独立执行一样!
持久性(Durability):一个成功执行得事务对数据库得作用是持久得,即使数据库应故障出错,也应该能够恢复!
MYSQL的事务处理主要有两种方法。
1、用begin,rollback,commit来实现
begin 开始一个事务
rollback 事务回滚
commit  事务确认
2、直接用set来改变mysql的自动提交模式
MYSQL默认是自动提交的,也就是你提交一个QUERY,它就直接执行!我们可以通过
set autocommit=0   禁止自动提交
set autocommit=1 开启自动提交
来实现事务的处理。
但注意当你用 set autocommit=0 的时候,你以后所有的SQL都将做为事务处理,直到你用commit确认或rollback结束,注意当你结束这个事务的同时也开启了个新的事务!按第一种方法只将当前的作为一个事务!
个人推荐使用第一种方法!
MYSQL中只有INNODB和BDB类型的数据表才能支持事务处理!其他的类型是不支持的!(切记!)
MYSQL5.0 WINXP下测试通过~ 
mysql> use test;
Database changed
mysql> CREATE TABLE `dbtest`(
-> id int(4)
-> ) TYPE=INNODB;
Query OK, 0 rows affected, 1 warning (0.05 sec)
mysql> select * from dbtest
-> ;
Empty set (0.01 sec)
mysql> begin;
Query OK, 0 rows affected (0.00 sec)
mysql> insert into dbtest value(5);
Query OK, 1 row affected (0.00 sec)
mysql> insert into dbtest value(6);
Query OK, 1 row affected (0.00 sec)
mysql> commit;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from dbtest;
+------+
| id    |
+------+
|     5 |
|     6 |
+------+
2 rows in set (0.00 sec)
mysql> begin;
Query OK, 0 rows affected (0.00 sec)
mysql> insert into dbtest values(7);
Query OK, 1 row affected (0.00 sec)
mysql> rollback;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from dbtest;

+------+
| id    |
+------+
|     5 |
|     6 |
+------+
2 rows in set (0.00 sec)
mysql>
*******************************************************************************************************************

代码如下:

function Tran( $sql ) {
$judge = 1;
mysql_query('begin');
foreach ($sql as $v) {
if ( !mysql_query($v) ) {
$judge = 0;
}
}
if ($judge == 0) {
mysql_query('rollback');
return false;
}
elseif ($judge == 1) {
mysql_query('commit');
return true;
}
}

************************************************
代码如下:


    
 
 

您可能感兴趣的文章:

  • mysql 事务处理及表锁定深入简析
  • mysql存储过程事务管理简析
  • 解析mysql二进制日志处理事务与非事务性语句的区别
  • MySQL C API中有没有事务处理的函数啊?
  • mysql 事务 回滚 提交
  • 基于mysql事务、视图、存储过程、触发器的应用分析
  • MYSQL事务回滚的2个问题分析
  • 为mysql数据库添加添加事务处理的方法
  • Mysql中的事务是什么如何使用
  • mysql实现事务的提交和回滚实例
  • mysql 锁表锁行语句分享(MySQL事务处理)
  • MySql的事务使用与示例详解
  • python连接mysql并提交mysql事务示例
  • PHP中执行MYSQL事务解决数据写入不完整等情况
  • MySql事务无法回滚的原因有哪些
  • mysql的XA事务恢复过程详解
  • MySQL数据库事务隔离级别介绍(Transaction Isolation Level)
  • 利用mysql事务特性实现并发安全的自增ID示例
  • MySQL存储过程例子(包含事务,输出参数,嵌套调用)
  • MySQL InnoDB之事务与锁详解
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux忘记mysql密码处理方法
  • 修改mysql密码与忘记mysql密码的处理方法
  • MySQL的化学处理扩展 Mychem
  • MySQL文本文件导入及批处理模式应用说明
  • MySQL 5.6 如何更改安全的处理密码探讨
  • mysql启用skip-name-resolve模式时出现Warning的处理办法
  • 请教:linux里取出mysql的数据为乱码,作了编码处理还是不行(java)
  • mysql从执行.sql文件时处理n换行的问题
  • 使用Linux的Shell脚本定时处理MySQL超时
  • 烦人:用Java操纵mySQL数据库时的中文字符处理。
  • windows下配置apache+php+mysql时出现问题的处理方法
  • PHP处理SQL脚本文件导入到MySQL的代码实例
  • mysql错误处理之ERROR 1665 (HY000)
  • mysql常见的错误提示问题处理小结
  • mysql错误处理之ERROR 1786 (HY000)
  • MySQL数据入库时特殊字符处理详解
  • mysql出现“Incorrect key file for table”处理方法
  • 请问shell能连接mysql数据库吗?具体怎么处理的阿,谢谢!
  • 基于Mysql的IP处理函数inet_aton()与inet_ntoa()的深入分析
  • MySQL 备份还原数据库批处理
  • mysql中如何查看最大连接数(max_connections)和修改最大连接数
  • 在 linux下输入"mysql"命令,进入mysql命令行,但出现“Can't connetc to local MySQL server thuough socket /var/lib/mysql/mysql.sock
  • Mysql查询错误:ERROR:no query specified原因
  • MySQL 重装MySQL后, mysql服务无法启动
  • php安装完成后如何添加mysql扩展
  • 为什么用linux安装盘安装了mysql后,启动mysql,提示找不到mysql.sock文件?
  • mysql中查询当前正在运行的SQL语句并找出mysql中运行慢的sql语句
  • 請教,在redhat linux7.2+mysql 中,系統提示mysql已啟動,網頁卻不能訪問mysql?
  • Myeclipse中自带Tomcat的JDBC连接池配置(mysql和mssql)
  • MySQL InnoDB之事务与锁详解 iis7站长之家
  • MySQL Workbench的下载安装与使用教程




  • 特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3