深入探討:MySQL數(shù)據(jù)庫MyISAM與InnoDB存儲引擎的比較
導(dǎo)讀:1建站知識MySQL有多種存儲引擎,MyISAM和InnoDB是其中常用的兩種。這里介紹關(guān)于這兩種引擎的一些基本概念(非深入介紹)。 MyISAM是MySQL的默認存儲引網(wǎng)站建設(shè)哪家好營銷型網(wǎng)站建設(shè)。
MySQL有多種存儲引擎,MyISAM和InnoDB是其中常用的兩種。這里介紹關(guān)于這兩種引擎的一些基本概念(非深入介紹)。
MyISAM是MySQL的默認存儲引擎,基于傳統(tǒng)的ISAM類型,支持全文搜索,但不是事務(wù)安全的,而且不支持外鍵。每張MyISAM表存放在三個文件中:frm 文件存放表格定義;數(shù)據(jù)文件是MYD (M個業(yè)網(wǎng)站建設(shè)公司YData);索引文件是MYI (MYIndex)。
InnoDB是事務(wù)型引擎,支持回滾、崩潰恢復(fù)能力、多版本并發(fā)控制、ACID事務(wù),支持行級鎖定(InnoDB表的行鎖不是絕對的,如果在執(zhí)行一個SQL語句時MySQL不能確定要掃描的范圍,InnoDB表同樣會鎖全表,如like操作時的SQL語句),以及提供與Oracle類型一致的不加鎖讀取方式。InnoDB存儲它的表和索引在一個表空間中,表空間可以包含數(shù)個文件。
主要區(qū)別:
•MyISAM是非事務(wù)安全型的,而InnoDB是事務(wù)安全型的。
•MyISAM鎖的粒度是表級,而InnoDB支持行級鎖定。
•MyISAM支持全文類型索引,而InnoDB不支持全如何seo優(yōu)化推廣網(wǎng)站文索引。
•MyISAM相對簡單,所以在效率上要優(yōu)于InnoDB,小型應(yīng)用可以考慮使用MyISAM。
•MyISAM表是保存成文件的形式,在跨平臺的數(shù)據(jù)轉(zhuǎn)移中使用MyISAM存儲會省去不少的麻煩。
•InnoDB表比MyISAM表更安全,可以在保證數(shù)據(jù)不會丟失的情況下,切換非事務(wù)表到事務(wù)表(alter table tablename type=innodb)。公司網(wǎng)站建設(shè)
應(yīng)用場景:
•MyISAM管理非事務(wù)表。它提供高速存儲和檢索,以及全文搜索能力。如果應(yīng)用中需要執(zhí)行大量的SELECT查詢,那么MyISAM是更好的選擇。
•InnoDB用于事務(wù)處理應(yīng)用程序,具有眾多特性,包括ACID事務(wù)支持。如果應(yīng)用中需要執(zhí)行大量的INSERT或UPDATE操作,則應(yīng)該使用InnoDB,這樣可以提高多用戶并發(fā)操作的性能。
常用命令:
(1)查看表的存儲類型(三種):
•show create table tablename
•show table status from dbname where name=tablename
•mysqlshow -u user -p password --status dbname tablename
(2)修改表的存儲引擎:
•alter table tablename type=InnoDB
(3)啟動mysql數(shù)據(jù)庫的命令行中添加以下參數(shù)使新發(fā)布的表都默認使用事務(wù):
•--default-table-type=InnoDB
(4)臨時改變默認表類型:
•set table_type=InnoDB
•show variables like 'table_type'
相關(guān)網(wǎng)站建設(shè)哪家好營銷型網(wǎng)站建設(shè)。
聲明: 本文由我的SEOUC技術(shù)文章主頁發(fā)布于:2023-05-23 ,文章深入探討:MySQL數(shù)據(jù)庫MyISAM與InnoDB存儲引擎的比較主要講述深入,標簽,SQL網(wǎng)站建設(shè)源碼以及服務(wù)器配置搭建相關(guān)技術(shù)文章。轉(zhuǎn)載請保留鏈接: http://www.bifwcx.com/article/web_6160.html