phpmysql事物,mysql 事物

本文目錄一覽:

php mysql 事務怎麼寫

建一張test表

set autocommit=0;//設置mysql不自動提交就是不自動執行sql語句

begin; //開啟一個事務

insert into test value(test);

insert into test value(test2);

commit;//提交 ,會執行上面2句sql語句 此時test 表裡面有 test 和 test2 2條數據

begin; //開啟一個事務

insert into test values(test3);

rollback; //回滾 , test表裡面並沒有test3 這條數據

通常 在php裡面會判斷 if(!mysql_query($sql)){mysql_query(‘rollback’);} 就是如果沒有成功執行sql就進行回滾,比如轉賬我給你10塊錢 先從我賬號裡面減去10元 再從你賬戶加10元 這就是2條sql 要保證都能執行完成

談談你對 mysql 事務的認識 我是php初學者不懂這個 想請教大神教我

先簡單介紹一下事務吧!事務是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類型的數據表才能支持事務處理!其他的類型是不支持的!(切記!)

下次有空說下MYSQL的數據表的鎖定和解鎖!

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

*******************************************************************************************************************

[PHP]

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;

}

}

[/PHP]

************************************************

?php

$handler=mysql_connect(“localhost”,”root”,””);

mysql_select_db(“task”);

mysql_query(“SET

AUTOCOMMIT=0″);//設置為不自動提交,因為MYSQL默認立即執行

mysql_query(“BEGIN”);//開始事務定義

if(!mysql_query(“insert

into trans (id)

values(‘2’)”))

{

mysql_query(“ROOLBACK”);//判斷當執行失敗時回滾

}

if(!mysql_query(“insert

into trans (id)

values(‘4’)”))

{

mysql_query(“ROOLBACK”);//判斷執行失敗回滾

}

mysql_query(“COMMIT”);//執行事務

mysql_close($handler);

?

引自:

php mysql事務能解決什麼問題

1、用begin,rollback,commit來實現

begin 開始一個事務

rollback 事務回滾

commit 事務確認

2、直接用set來改變mysql的自動提交模式

MYSQL默認是自動提交的,也就是你提交一個QUERY,它就直接執行!我們可以通過

set autocommit=0 禁止自動提交

set autocommit=1 開啟自動提交

來實現事務的處理。

php關於mysql資料庫簡單回滾問題

我們經常會遇到操作一張大表,發現操作時間過長或影響在線業務了,想要回退大表操作的場景。在我們停止大表操作之後,等待回滾是一個很漫長的過程,儘管你可能對知道一些縮短時間的方法,處於對生產環境數據完整性的敬畏,也會選擇不做介入。最終選擇不作為的原因大多源於對操作影響的不確定性。實踐出真知,下面針對兩種主要提升事務回滾速度的方式進行驗證,一種是提升操作可用內存空間,一種是通過停實例,禁用 redo 回滾方式進行進行驗證。

仔細閱讀過官方手冊的同學,一定留意到了對於提升大事務回滾效率,官方提供了兩種方法:一是增加 innodb_buffer_pool_size 參數大小,二是合理利用 innodb_force_recovery=3 參數,跳過事務回滾過程。第一種方式比較溫和,innodb_buffer_pool_size 參數是可以動態調整的,可行性也較高。第二種方式相較之下較暴力,但效果較好。

兩種方式各有自己的優點,第一種方式對線上業務系統影響較小,不會中斷在線業務。第二種方式效果更顯著,會短暫影響業務連續,回滾所有沒有提交的事務。

php 開啟mysql事務,會自動提交么

您好,MySQL提交方式autocommit默認開啟,這種模式本身就是以每次查詢為一次單獨的事務。

當開啟事務後,直到執行commit語句才會提交,所以不會自動提交,否則我們開啟事務也沒有意義了呀。

希望能幫到您。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/238767.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 12:13
下一篇 2024-12-12 12:13

相關推薦

  • 如何修改mysql的埠號

    本文將介紹如何修改mysql的埠號,方便開發者根據實際需求配置對應埠號。 一、為什麼需要修改mysql埠號 默認情況下,mysql使用的埠號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL資料庫 在使用Python操作MySQL之前,我們需要先連接MySQL資料庫。在Python中,我…

    編程 2025-04-29
  • MySQL遞歸函數的用法

    本文將從多個方面對MySQL遞歸函數的用法做詳細的闡述,包括函數的定義、使用方法、示例及注意事項。 一、遞歸函數的定義 遞歸函數是指在函數內部調用自身的函數。MySQL提供了CRE…

    編程 2025-04-29
  • MySQL bigint與long的區別

    本文將從數據類型定義、存儲空間、數據範圍、計算效率、應用場景五個方面詳細闡述MySQL bigint與long的區別。 一、數據類型定義 bigint在MySQL中是一種有符號的整…

    編程 2025-04-28
  • MySQL左連接索引不生效問題解決

    在MySQL資料庫中,經常會使用左連接查詢操作,但是左連接查詢中索引不生效的情況也比較常見。本文將從多個方面探討MySQL左連接索引不生效問題,並給出相應的解決方法。 一、索引的作…

    編程 2025-04-28
  • CentOS 7在線安裝MySQL 8

    在本文中,我們將介紹如何在CentOS 7操作系統中在線安裝MySQL 8。我們會從安裝環境的準備開始,到安裝MySQL 8的過程進行詳細的闡述。 一、環境準備 在進行MySQL …

    編程 2025-04-27
  • 如何使用MySQL欄位去重

    本文將從多個方面為您詳細介紹如何使用MySQL欄位去重並給出相應的代碼示例。 一、SELECT DISTINCT語句去重 MySQL提供了SELECT DISTINCT語句,通過在…

    編程 2025-04-27
  • MySQL正則表達式替換

    MySQL正則表達式替換是指通過正則表達式對MySQL中的字元串進行替換。在文本處理方面,正則表達式是一種強大的工具,可以方便快捷地進行字元串處理和匹配。在MySQL中,可以使用正…

    編程 2025-04-27
  • Apache2.4和MySQL的全能編程開發工程師指南

    本文將從多個方面對Apache2.4和MySQL進行詳細的闡述,為全能編程開發工程師提供有用的參考和指導。首先,我們來解答這個標題所涵蓋的主題: 本文將提供Apache2.4和My…

    編程 2025-04-27
  • MySQL JDBC驅動包下載詳解

    一、JDBC驅動介紹 JDBC是Java Database Connectivity的縮寫,它是Java應用程序與各種資料庫連接的標準API,允許Java程序員使用JDBC API…

    編程 2025-04-25

發表回復

登錄後才能評論