標籤:
本人應用的MySQL的版本為:5.6.22
MySQL5.5以後預設使用InnoDB儲存引擎,其中InnoDB和BDB提供事務安全表,其它儲存引擎都是非事務安全表. 可以通過engine關鍵字在建立或修改資料庫時指定所使用到引擎。主要儲存引擎:MyISAM、InnoDB、MEMORY和MERGE介紹,通過執行個體主要講解下MyISAM與InnoDB在事務上應用區別
(一)MyISAM
它不支援事務,也不支援外鍵,尤其是訪問速度快,對事務完整性沒有要求或者以SELECT、INSERT為主的應用基本都可以使用這個引擎來建立表。
每個MyISAM在磁碟上儲存成2個檔案,其中檔案名稱和表名都相同,但是副檔名分別為:
(二)InnoDB
InnoDB儲存引擎提供了具有提交、復原和崩潰恢複能力的事務安全。但是對比MyISAM的儲存引擎,InnoDB寫的處理效率差一些並且會佔用更多的磁碟空間以保留資料和索引。
執行個體一:(1) 建立測試應用的表結構如下,儲存引擎選擇MySAM
Create Table: CREATE TABLE `t1` (
`id` int(6) DEFAULT NULL,
`id2` int(6) DEFAULT NULL,
`name` varchar(18) NOT NULL DEFAULT ‘zhaolf‘
) ENGINE=MyISAM DEFAULT CHARSET=utf8
(2) 插入測試應用資料 mysql> select * from t1;
+------+------+------+
| id | id2 | name |
+------+------+------+
| 2 | 1 | dbdh |
| 8 | 8 | 8 |
| 7 | 7 | 7 |
+------+------+------+
3 rows in set (0.00 sec)
(3) 操作
mysql> savepoint t1;
Query OK, 0 rows affected (0.00 sec)
mysql> insert into t1 values(3,3,3);
Query OK, 1 row affected (0.01 sec)
mysql> select * from t1;
+------+------+------+
| id | id2 | name |
+------+------+------+
| 2 | 1 | dbdh |
| 8 | 8 | 8 |
| 7 | 7 | 7 |
| 3 | 3 | 3 |
+------+------+------+
4 rows in set (0.00 sec)
mysql> rollback to t1;
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> select * from t1;
+------+------+------+
| id | id2 | name |
+------+------+------+
| 2 | 1 | dbdh |
| 8 | 8 | 8 |
| 7 | 7 | 7 |
| 3 | 3 | 3 |
+------+------+------+
4 rows in set (0.00 sec)
// 根據以上得知MySAM沒有對事務做支援
執行個體二: 表為t1,儲存引擎修改為InnoDB
(1) 第一步:修改為不自動認可模式
mysql> alter table t1 engine=innodb;
Query OK, 4 rows affected (0.62 sec)
Records: 4 Duplicates: 0 Warnings: 0
mysql> show create table t1\G
*************************** 1. row ***************************
Table: t1
Create Table: CREATE TABLE `t1` (
`id` int(6) DEFAULT NULL,
`id2` int(6) DEFAULT NULL,
`name` varchar(18) NOT NULL DEFAULT ‘zhaolf‘
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)
mysql>
(2) 事務操作
mysql> savepoint t1;
Query OK, 0 rows affected (0.00 sec)
mysql> delete from t1 where id =3;
Query OK, 1 row affected (0.00 sec)
mysql> rollback to t1;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from t1;
+------+------+------+
| id | id2 | name |
+------+------+------+
| 2 | 1 | dbdh |
| 8 | 8 | 8 |
| 7 | 7 | 7 |
+------+------+------+
4 rows in set (0.00 sec)
mysql>
通過執行個體說明兩種儲存引擎的區別.
MySQL 事務1