Heim Datenbank MySQL-Tutorial Mysql事务处理_MySQL

Mysql事务处理_MySQL

Jun 01, 2016 pm 01:01 PM
事务

事务处理在各种管理系统中都有着广泛的应用,比如人员管理系统,很多同步数据库操作大都需要用到事务处理。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!
删除的SQL语句

deletefrom userinfo where ~~~
delete from mail where ~~
delete fromarticle where~~
~~
Nach dem Login kopieren


如果没有事务处理,在你删除的过程中,假设出错了,只执行了第一句,那么其后果是难以想象的!
但用事务处理。如果删除出错,你只要rollback就可以取消删除操作(其实是只要你没有commit你就没有确实的执行该删除操作)

一般来说,在商务级的应用中,都必须考虑事务处理的!

查看inodb信息
shell> /usr/local/mysql -u root -p
mysql> showvariables 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.05sec)
Nach dem Login kopieren

如果是这样的,那么我们就可以创建一张支持事务处理的表来试试了。

MYSQL的事务处理功能!

作者:Feifengxlq Email:feifengxlq@sohu.com
一直以来我都以为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 开启自动提交
来实现事务的处理。
但注意当你用setautocommit=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 rowsaffected, 1 warning (0.05 sec)

mysql> select * from dbtest
-> ;
Empty set (0.01 sec)

mysql> begin;
QueryOK, 0 rows affected (0.00 sec)

mysql> insert into dbtestvalue(5);
Query OK, 1 row affected (0.00 sec)

mysql>insert into dbtest value(6);
Query OK, 1 row affected (0.00sec)

mysql> commit;
Query OK, 0 rows affected (0.00sec)

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

mysql> begin;
Query OK, 0 rows affected (0.00sec)

mysql> insert into dbtest values(7);
Query OK, 1row affected (0.00 sec)

mysql> rollback;
Query OK, 0rows affected (0.00 sec)

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

mysql>

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

[PHP]
functionTran( $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("SETAUTOCOMMIT=0");//设置为不自动提交,因为MYSQL默认立即执行
mysql_query("BEGIN");//开始事务定义
if(!mysql_query("insertinto trans (id)values(&#39;2&#39;)"))
{
mysql_query("ROOLBACK");//判断当执行失败时回滚
}
if(!mysql_query("insertinto trans (id)values(&#39;4&#39;)"))
{
mysql_query("ROOLBACK");//判断执行失败回滚
}
mysql_query("COMMIT");//执行事务
mysql_close($handler);
?>
Nach dem Login kopieren
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Sperrwartezeitüberschreitung überschritten; versuchen Sie, die Transaktion neu zu starten – So beheben Sie den MySQL-Fehler: Transaktionswartezeitüberschreitung Sperrwartezeitüberschreitung überschritten; versuchen Sie, die Transaktion neu zu starten – So beheben Sie den MySQL-Fehler: Transaktionswartezeitüberschreitung Oct 05, 2023 am 08:46 AM

Lockwaittimeoutexceeded;tryrestartingtransaction – So beheben Sie den MySQL-Fehler: Transaktionswartezeitüberschreitung Bei Verwendung der MySQL-Datenbank kann es manchmal zu einem häufigen Fehler kommen: Lockwaittimeoutexceeded;tryrestartingtransaction. Dieser Fehler weist auf eine Transaktionswartezeitüberschreitung hin. Dieser Fehler tritt normalerweise auf, wenn

MySQL-Transaktionsverarbeitung: Der Unterschied zwischen automatischer Übermittlung und manueller Übermittlung MySQL-Transaktionsverarbeitung: Der Unterschied zwischen automatischer Übermittlung und manueller Übermittlung Mar 16, 2024 am 11:33 AM

MySQL-Transaktionsverarbeitung: Der Unterschied zwischen automatischer Übermittlung und manueller Übermittlung. In der MySQL-Datenbank ist eine Transaktion eine Reihe von SQL-Anweisungen. Entweder sind alle Ausführungen erfolgreich oder alle Ausführungen schlagen fehl, wodurch die Konsistenz und Integrität der Daten sichergestellt wird. In MySQL können Transaktionen in automatische Übermittlung und manuelle Übermittlung unterteilt werden. Der Unterschied liegt im Zeitpunkt der Transaktionsübermittlung und im Umfang der Kontrolle über die Transaktion. Im Folgenden wird der Unterschied zwischen automatischer Übermittlung und manueller Übermittlung ausführlich vorgestellt und spezifische Codebeispiele zur Veranschaulichung gegeben. 1. Automatisch in MySQL übermitteln, wenn es nicht angezeigt wird

Die Prinzipien und Anwendungsszenarien von MySQL-Transaktionen Die Prinzipien und Anwendungsszenarien von MySQL-Transaktionen Mar 02, 2024 am 09:51 AM

Das Prinzip und die Anwendungsszenarien von MySQL-Transaktionen Im Datenbanksystem ist eine Transaktion eine Reihe von SQL-Operationen, die entweder alle erfolgreich ausgeführt werden oder alle fehlschlagen und zurückgesetzt werden. Als häufig verwendetes relationales Datenbankverwaltungssystem unterstützt MySQL Transaktionsmerkmale und kann sicherstellen, dass die Daten in der Datenbank hinsichtlich Konsistenz, Isolation, Haltbarkeit und Atomizität garantiert sind. Dieser Artikel beginnt mit den Grundprinzipien von MySQL-Transaktionen, stellt deren Anwendungsszenarien vor und stellt spezifische Codebeispiele als Referenz für die Leser bereit. Das Prinzip der MySQL-Transaktionen: My

PHP PDO-Tutorial: Ein Leitfaden für Fortgeschrittene von den Grundlagen bis zur Beherrschung PHP PDO-Tutorial: Ein Leitfaden für Fortgeschrittene von den Grundlagen bis zur Beherrschung Feb 19, 2024 pm 06:30 PM

1. Einführung in PDO PDO ist eine Erweiterungsbibliothek von PHP, die eine objektorientierte Möglichkeit zum Betrieb der Datenbank bietet. PDO unterstützt eine Vielzahl von Datenbanken, einschließlich MySQL, Postgresql, Oracle, SQLServer usw. PDO ermöglicht Entwicklern die Verwendung einer einheitlichen API zum Betrieb verschiedener Datenbanken, wodurch Entwickler problemlos zwischen verschiedenen Datenbanken wechseln können. 2. PDO stellt eine Verbindung zur Datenbank her. Um PDO zum Herstellen einer Verbindung zur Datenbank zu verwenden, müssen Sie zunächst ein PDO-Objekt erstellen. Der Konstruktor des PDO-Objekts erhält drei Parameter: Datenbanktyp, Hostname, Datenbankbenutzername und Passwort. Der folgende Code erstellt beispielsweise ein Objekt, das eine Verbindung zu einer MySQL-Datenbank herstellt: $dsn="mysq

Wie verarbeitet die Java-Datenbankverbindung Transaktionen und Parallelität? Wie verarbeitet die Java-Datenbankverbindung Transaktionen und Parallelität? Apr 16, 2024 am 11:42 AM

Transaktionen gewährleisten die Integrität der Datenbankdaten, einschließlich Atomizität, Konsistenz, Isolation und Haltbarkeit. JDBC verwendet die Verbindungsschnittstelle, um die Transaktionssteuerung bereitzustellen (setAutoCommit, Commit, Rollback). Parallelitätskontrollmechanismen koordinieren gleichzeitige Vorgänge mithilfe von Sperren oder optimistischer/pessimistischer Parallelitätskontrolle, um eine Transaktionsisolation zu erreichen und Dateninkonsistenzen zu verhindern.

Beherrschen Sie die Leistungsfähigkeit von PHP PDO: erweiterte Abfragen und Aktualisierungen Beherrschen Sie die Leistungsfähigkeit von PHP PDO: erweiterte Abfragen und Aktualisierungen Feb 20, 2024 am 08:24 AM

Die PHP Data Objects (PDO)-Erweiterung ermöglicht eine effiziente und objektorientierte Interaktion mit Datenbankservern. Seine erweiterten Abfrage- und Aktualisierungsfunktionen ermöglichen es Entwicklern, komplexe Datenbankoperationen durchzuführen und so die Leistung und Wartbarkeit des Codes zu verbessern. Dieser Artikel befasst sich mit den erweiterten Abfrage- und Aktualisierungsfunktionen von PDO und führt Sie durch die Beherrschung seiner leistungsstarken Funktionen. Erweiterte Abfragen: Platzhalter und gebundene Parameter verwenden Platzhalter und gebundene Parameter sind wichtige Werkzeuge zur Verbesserung der Abfrageleistung und -sicherheit. Platzhalter verwenden Fragezeichen (?), um ersetzbare Parameter in der Abfrage darzustellen, während Bind-Parameter es Ihnen ermöglichen, den Datentyp und den Wert jedes Parameters anzugeben. Durch die Verwendung dieser Methoden können Sie SQL-Injection-Angriffe vermeiden und die Leistung verbessern, da die Datenbank-Engine Abfragen im Voraus optimieren kann. //Platzhalter $stmt=$ verwenden

Lokalisierung und Reparatur von PHP-Transaktionsfehlern Lokalisierung und Reparatur von PHP-Transaktionsfehlern Mar 23, 2024 am 11:09 AM

Methoden zur Lokalisierung und Reparatur von PHP-Transaktionsfehlern Während des Entwicklungsprozesses sind häufig Datenbankoperationen beteiligt. Um die Integrität und Konsistenz der Daten sicherzustellen, verwenden wir bei der Verarbeitung von Datenbankvorgängen häufig Transaktionen, um die Atomizität einer Reihe von Vorgängen sicherzustellen. Im eigentlichen Entwicklungsprozess treten jedoch manchmal Fehler in Transaktionen auf, die zu unvollständigen oder inkonsistenten Datenoperationen führen. In diesem Artikel wird erläutert, wie Sie Transaktionsfehler in PHP finden und beheben, und es werden konkrete Codebeispiele bereitgestellt. Um Transaktionsfehler in PHP zu lokalisieren, können wir MySQLi oder verwenden

Welche Transaktionsverarbeitungstechniken gibt es zum Erlernen von MySQL? Welche Transaktionsverarbeitungstechniken gibt es zum Erlernen von MySQL? Jul 30, 2023 pm 10:13 PM

Welche Transaktionsverarbeitungstechniken gibt es zum Erlernen von MySQL? Einleitung: Transaktionen sind ein sehr wichtiges Konzept in Datenbankverwaltungssystemen. Sie bieten einen Mechanismus zur Gewährleistung der Datenintegrität und -konsistenz. In MySQL ist eine Transaktion die Ausführungseinheit einer Reihe von SQL-Anweisungen, die sicherstellen kann, dass alle SQL-Anweisungen in dieser Reihe von Anweisungen entweder erfolgreich ausgeführt werden oder zurückgesetzt werden, wenn die gesamte Ausführung fehlschlägt. In diesem Artikel werden die Transaktionsverarbeitungsfähigkeiten beim Erlernen von MySQL vorgestellt und entsprechende Codebeispiele gegeben. Starten Sie eine Transaktion: In MySQL können Sie BEGIN und STARTTRAN verwenden

See all articles