目次
存储引擎及事务概念
一、存储引擎
ホームページ データベース mysql チュートリアル 小贝_mysql存储引擎及事务概念_MySQL

小贝_mysql存储引擎及事务概念_MySQL

Jun 01, 2016 pm 12:59 PM
事務 コンセプト

存储引擎及事务概念

简要:
1、什么是存储引擎
2、什么是事务

 

一、存储引擎

 

通俗地讲就是存储和管理数据的方式

形象例子:

 

某处地方的自行车管理员:李某,张某。每天都有很多人来存取自行车。李某的管理方式是: 车主自行存放,李某也不记录对方存的是什么车。取车时则要交管理费。也不检查取的是否是对方自己的车。相反,张某,则在车主存放车时,记录存放人的特征以及对应车的信息。当人来取车时,张某还要小心核对,人与车的特征是否对应。

 

从上述例子可知:

 

a、从效率的角度来看: 李某比张某快,因为其不用进行校对

 

b、从安全性的角度来看: 张某比李某要安全,因为其进行了校对。

 

总结: 实际上,mysql的存储引擎也是这样工作,每种存储引擎都有自身的存取方式,因此在选择上,应该根据实际情况来定。

 

1、如何查看mysql的引擎

mysql> show engines;

 

2、常用的存储引擎myisam与innodb的区别

2.1、myisam: 批量插入速度快,不支持事务,表锁

innodb:批量插入速度相对较慢,支持事务,行锁

 

 

二、事务

通俗地理解,指一组操作,要么都成功执行,要么都不执行。

例如:

用户A给用户B转账500元

先分析下这个流程:

1、判断用户A的卡余额是否大于500元,否则,则无法进行转账操作

2、在满足大于500元的基础上,用户A给用户B进行转账

3、转账操作成功,则用户A的卡余额减去500元,用户B加上500元

用程序描述下这个过程

 

ログイン後にコピー
ログイン後にコピー

<!--?php
$userA = $momeyA;
$userB = $momeyB;
if( $moneyA < 500 )
{
return false;
}
$sqlA = "update user set money=money-500 where name=&#39;userA&#39;";   //步骤A
$resultA = $db--->query($sqlA);
if( $resultA )
{
$sqlB = "update user set money=money+500 where name=&#39;userB&#39;";	//步骤B
$resultB = $db->query($sqlB);	
if( $resultB )
{
	return true;
}else
{
$sqlA = "update user set money=money+500 where name=&#39;userA&#39;";	//步骤C
$resultA = $db->query($sqlA);
return false;
}
}
$sqlA = "update user set money=money+500 where name=&#39;userA&#39;";	//步骤D
$resultA = $db->query($sqlA);
return false;
?>
ログイン後にコピー

ログイン後にコピー
ログイン後にコピー
 

 

从事务的角度看:

1、在转账过程中,出现有误,则该错误对双方而言,是没有影响的。即不可能因为某个错误,导致用户A白白减少500,而用户B莫名其妙多了500

2、在转账过程中,用户A是不可能看到自己的卡余额减下500,而用户B也是无法看到自己增加500元,因为转账操作还未结束。

3、单单从这个过程,用户A与用户B的总金额是不变的。只不过是一方减少,另一方增加

总结下事务的几个特性

a、 原子性:一组操作,要么都成功执行,要么都不执行

b、 隔离性:在所有的操作没有执行完毕之前,其它会话不能够看到中间改变的过程

c、 一致性:事务发生前和发生后,数据的总额依然匹配

d、 持久性:事务产生的影响不能够撤销

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

ロック待機タイムアウトを超過しました。トランザクションを再起動してください - MySQL エラーの解決方法: トランザクション待機タイムアウト ロック待機タイムアウトを超過しました。トランザクションを再起動してください - MySQL エラーの解決方法: トランザクション待機タイムアウト Oct 05, 2023 am 08:46 AM

ロック待機タイムアウトを超過しました。トランザクションを再起動してください - MySQL エラーの解決方法: トランザクション待機タイムアウト

メタバースの概念は何を意味しますか? メタバースの概念とは何ですか? メタバースの概念は何を意味しますか? メタバースの概念とは何ですか? Feb 22, 2024 pm 03:55 PM

メタバースの概念は何を意味しますか? メタバースの概念とは何ですか?

Gunicorn の基本と機能について詳しく知る Gunicorn の基本と機能について詳しく知る Jan 03, 2024 am 08:41 AM

Gunicorn の基本と機能について詳しく知る

クラスの概念を使用して長方形の面積と周囲長を計算する Java プログラムを作成します。 クラスの概念を使用して長方形の面積と周囲長を計算する Java プログラムを作成します。 Sep 03, 2023 am 11:37 AM

クラスの概念を使用して長方形の面積と周囲長を計算する Java プログラムを作成します。

MySQL トランザクション処理: 自動送信と手動送信の違い MySQL トランザクション処理: 自動送信と手動送信の違い Mar 16, 2024 am 11:33 AM

MySQL トランザクション処理: 自動送信と手動送信の違い

Spring MVC の主要な概念をマスターする: これらの重要な機能を理解する Spring MVC の主要な概念をマスターする: これらの重要な機能を理解する Dec 29, 2023 am 09:14 AM

Spring MVC の主要な概念をマスターする: これらの重要な機能を理解する

Oracle RAC の概要と中心となる概念 Oracle RAC の概要と中心となる概念 Mar 07, 2024 am 11:39 AM

Oracle RAC の概要と中心となる概念

Oracle ホーム ディレクトリとは何ですか? Oracleホームディレクトリの概念と機能の詳細説明 Oracle ホーム ディレクトリとは何ですか? Oracleホームディレクトリの概念と機能の詳細説明 Mar 08, 2024 am 08:18 AM

Oracle ホーム ディレクトリとは何ですか? Oracleホームディレクトリの概念と機能の詳細説明

See all articles