PHP简单的事务测试用例
show engines; +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+ | Engine | Support | Comment | Transactions | XA | Savepoints | +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+ | FEDERATED | NO | Federated MySQL storage engine | NULL | NULL | NULL | | MRG_MYISAM | YES | Collection of identical MyISAM tables | NO | NO | NO | | MyISAM | YES | MyISAM storage engine | NO | NO | NO | | BLACKHOLE | YES | /dev/null storage engine (anything you write to it disappears) | NO | NO | NO | | CSV | YES | CSV storage engine | NO | NO | NO | | MEMORY | YES | Hash based, stored in memory, useful for temporary tables | NO | NO | NO | | ARCHIVE | YES | Archive storage engine | NO | NO | NO | | InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES | YES | YES | | PERFORMANCE_SCHEMA | YES | Performance Schema | NO | NO | NO | +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+ // schemal create table transaction_tbl ( name char(10) not null ) engine=innodb; */ class Transaction { // 判断插入查询是否成功 private $error = 0; // 连接资源 private $conn_id = null; public function __construct() { $this->connect(); } public function test() { echo "BEGIN TEST\n"; //开始事务 $this->beginTransaction(); // 插入测试数据 // name 的大小限制为10 $str1 = str_repeat("a", mt_rand(1, 13)); $str2 = str_repeat("b", mt_rand(1, 13)); $this->query("INSERT INTO `transaction_tbl` (`name`) VALUES ('$str1')"); $this->query("INSERT INTO `transaction_tbl` (`name`) VALUES ('$str2')"); //提交查询 if ($this->error == 0) { $this->commit(); } else { $this->rollback(); } echo "END TEST\n"; } private function query($sql) { echo $sql."\n"; (mysql_query($sql, $this->conn_id) == FALSE) && ++$this->error; } // 开始事务 private function beginTransaction() { mysql_query("BEGIN", $this->conn_id); } //回滚 private function rollback() { echo "ROLLBACK\n"; mysql_query("ROLLBACK", $this->conn_id); } //提交 private function commit() { echo "save done\n"; mysql_query("COMMIT", $this->conn_id); } // 连接数据库 private function connect() { $this->conn_id = @mysql_connect("127.0.0.1", "root", "") or die("can\'t connect: ". mysql_error()); mysql_select_db("test", $this->conn_id) or die("can\'t use test: ". mysql_error()); } // 关闭数据 private function close() { mysql_close($this->conn_id); } public function __destruct() { $this->close(); } } $trans = new Transaction(); $trans->test();
Salin selepas log masuk
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas
R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu
By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
4 minggu yang lalu
By 尊渡假赌尊渡假赌尊渡假赌
Berapa lama masa yang diperlukan untuk mengalahkan fiksyen berpecah?
3 minggu yang lalu
By DDD
R.E.P.O. Simpan Fail Lokasi: Di manakah & bagaimana untuk melindunginya?
3 minggu yang lalu
By DDD

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)
