mysql的事务处理与锁表
来源:互联网 发布:短域名生成 编辑:程序博客网 时间:2024/06/03 20:56
数据库的事务处理可以保证一组处理结果的正确性。mysql中只有INNODB和BDB引擎的数据表才支持事务处理,对于不支持事务的MyISAM引擎数据库可以使用表锁定的方法来实现相同的功能。
mysql的事务处理主要有两种方法来实现。
1、用begin,rollback,commit来实现。
begin 开始一个事务
rollback 事务回滚
commit 事务确认
Php代码
- $conn = mysql_connect('localhost','root','root') or die ("数据连接错误!!!");
- mysql_select_db('test',$conn);
- mysql_query("set names 'utf8'");
- //开始一个事务
- mysql_query("BEGIN"); //或者mysql_query("START TRANSACTION");
- $sql = "INSERT INTO `t_user` (`id`, `username`, `sex`) VALUES (NULL, 'test1', '0')";
- $sql2 = "INSERT INTO `t_user` (`did`, `username`, `sex`) VALUES (NULL, 'test1', '0')";//这条是故意写错
- $res = mysql_query($sql);
- $res1 = mysql_query($sql2);
- if($res && $res1){
- mysql_query("COMMIT");
- echo '提交成功。';
- }else{
- mysql_query("ROLLBACK");
- echo '数据回滚。';
- }
- mysql_query("END");
2、直接用set来改变mysql的自动提交模式
MYSQL默认是自动提交的,也就是你提交一个QUERY,它就直接执行!我们可以通过
set autocommit=0 禁止自动提交
set autocommit=1 开启自动提交
Php代码
- $conn = mysql_connect('localhost','root','root') or die ("数据连接错误!!!");
- mysql_select_db('test',$conn);
- mysql_query("set names 'utf8'");
- mysql_query("SET AUTOCOMMIT=0"); //设置mysql不自动提交,需自行用commit语句提交
- $sql = "INSERT INTO `t_user` (`id`, `username`, `sex`) VALUES (NULL, 'test1', '0')";
- $sql2 = "INSERT INTO `t_user` (`did`, `username`, `sex`) VALUES (NULL, 'test1', '0')";//这条故意写错
- $res = mysql_query($sql);
- $res1 = mysql_query($sql2);
- if($res && $res1){
- mysql_query("COMMIT");
- echo '提交成功。';
- }else{
- mysql_query("ROLLBACK");
- echo '数据回滚。';
- }
- mysql_query("END"); //事务处理完时别忘记mysql_query("SET AUTOCOMMIT=1");自动提交
对于不支持事务的MyISAM引擎数据库可以使用表锁定的方法来实现
MyISAM & InnoDB 都支持,LOCK TABLES可以锁定用于当前线程的表。如果表被其它线程锁定,则造成堵塞,直到可以获取所有锁定为止。UNLOCK TABLES可以释放被当前线程保持的任何锁定。当线程发布另一个LOCK TABLES时,或当与服务器的连接被关闭时,所有由当前线程锁定的表被隐含地解锁。
Php代码
- mysql_query("LOCK TABLES `t_user` WRITE");//锁住`user`表
- $sql = "INSERT INTO `t_user` (`id`, `username`, `sex`) VALUES (NULL, 'test1', '0')";
- $res = mysql_query($sql);
- if($res){
- echo '提交成功。!';
- }else{
- echo '失败!';
- }
- mysql_query("UNLOCK TABLES");//解除锁定
如果操作表比较多,采用断点调试的时候,在事务处理完成之前(COMMIT)查看数据库的相关表是看不到表中数据的变化的。
下面是在mysql存储过程中使用事务处理的一个例子。
Java代码
- CREATE PROCEDURE TransTest(in p1 VARCHAR(20),in p2 VARCHAR(50))
- BEGIN
- declare err int default 0;
- /*如果出现sql异常,则将err设置为1后继续执行后面的操作 */
- declare continue handler for sqlexception set err=1; -- 出错处理
- set autocommit = 0;
- insert into sy_queryconfig(syq_id) values(p1);
- insert into sy_queryconfig(syq_id) values(p2);
- if err=1 then
- ROLLBACK;
- ELSE
- COMMIT;
- end if;
- END
PS:附加一个mysql数据库在delete表数据的时候,不能用别名操作,例如:
delete from t_user where id in (1,2);//此写法正确delete from t_user t where t.id in (1,2);//此写法错误
mysql就是这么任性!
技术分享:凯哥学堂
- mysql的事务处理与锁表
- Oracle与Mysql数据的事务处理机制
- MySQL事务处理与事务隔离(锁机制)
- PHP与MYSQL事务处理
- php与mysql事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- PHP与MYSQL事务处理
- 最大似然估计、最大后验估计、贝叶斯估计
- Java多线程四:线程间通信/等待唤醒机制
- Day10、指针与函数、数组
- A. Hulk
- day09__Python的Socket协议介绍
- mysql的事务处理与锁表
- ajax 文件拖拽上传
- Javaweb第一课:配置Tomcat服务器、搭建web开发环境、管理webapps项目
- Git 入门
- Android的内存分配与回收
- android中xml tools属性详解
- "accumulate"的思考
- 字符串交错组成(动态规划)
- [9] Palindrome Number