搜尋
首頁資料庫mysql教程Mysql資料庫中的儲存引擎是什麼

    儲存引擎

    什麼是儲存引擎?

    就像飛機和火箭中的引擎一樣,儲存引擎是資料庫中非常關鍵的組成部分。顯然不行,因為儲存引擎的使用必須基於特定的場景。而在Mysql中,儲存引擎也是一樣的,其沒有好壞之分。我們需要選擇適當的儲存引擎來適應不同的場景,才能做到最好。儲存引擎就是儲存資料、建立索引、更新/查詢資料等技術的實現方式。表類型可以被稱為儲存引擎,因為儲存引擎是基於表而非庫。

    Mysql的體系結構:

    Mysql的體系結構分為四層:

    MYsql的體系結構如下圖所示:

    Mysql資料庫中的儲存引擎是什麼

    #連線層

    最上層是一些客戶端和連結服務,主要完成一些類似連線處理,授權認證,及相關的安全方案,伺服器也會為安全存取的每個客戶端驗證它所具有的操作權限。

    服務層

    第二層架構主要完成大多數的核心服務功能,如SOL接口,並完成緩存的查詢,SOL的分析和優化,部分內建函數的執行。所有跨儲存引擎的功能也在這一層實現,如 流程、函數等。

    引擎層

    儲存引擎是MvSOL中負責資料儲存和提取的關鍵元件,伺服器與儲存引擎通信,使用API​​。根據需要選取適合的儲存引擎,因為不同的儲存引擎具有不同的功能。

    儲存層

    主要是將資料儲存在檔案系統之上:並完成與儲存引擎的互動。

    儲存引擎的檢視

    從MySQL 5.5開始,InnoDB儲存引擎成為預設的儲存引擎,當然還有其他多種儲存引擎可供選擇。之前預設的是Memory 儲存引擎。

    show engines;

    Mysql資料庫中的儲存引擎是什麼

    create table Course(
        Con int primary key auto_increment,
        Cname varchar(10),
        Cpon int,
        Ccredit int
    )
    
    show create table course;

    Mysql資料庫中的儲存引擎是什麼

    儲存引擎的指定

    例如,我們可以在建立表格的同時,指定此表的儲存引擎類型。

    create table test_mysql(
        name varchar(10),
        age int
    ) engine = Memory;

    Mysql資料庫中的儲存引擎是什麼

    儲存引擎的特點

    #這裡重點介紹以下InnoDB

    InnoDB介紹

    InnoDB是一種兼顧高可靠性和高效能的通用儲存引擎,在MvSOL 5.5 之後,InnoDB是預設的MvSOL儲存引擎。

    InnoDB特點
    • DML操作遵循ACID模型,支援交易;

    • ##行級鎖定,提高並發存取效能;

    • #支援外鍵FOREIGN KEY約束,保證資料的完整性與正確性:

     InnoDB檔案
    • #xxx.ibd:xxx代表的是表名,innoDB引擎的每個表都會對應這樣一個表空間文件,儲存該表的表結構(frm、sdi)、資料和索引。

    • 參數:innodb file per table

    Mysql資料庫中的儲存引擎是什麼

     

    最後用一張圖,來展示一下InnoDB 的邏輯儲存結構。

    Mysql資料庫中的儲存引擎是什麼

    Mysql資料庫中的儲存引擎是什麼

    總結:InnoDB 是支援交易的,而MyISAM不支援;InnoDB 是支援行鎖的,而MyISAM不支持,支援表鎖定;InnoDB 是支援外鍵的,而MyISAM不支援;

    儲存引擎的選擇

    Mysql資料庫中的儲存引擎是什麼

    以上是Mysql資料庫中的儲存引擎是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

    陳述
    本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除
    在MySQL中使用視圖的局限性是什麼?在MySQL中使用視圖的局限性是什麼?May 14, 2025 am 12:10 AM

    mysqlviewshavelimitations:1)他們不使用Supportallsqloperations,限制DatamanipulationThroughViewSwithJoinsOrsubqueries.2)他們canimpactperformance,尤其是withcomplexcomplexclexeriesorlargedatasets.3)

    確保您的MySQL數據庫:添加用戶並授予特權確保您的MySQL數據庫:添加用戶並授予特權May 14, 2025 am 12:09 AM

    porthusermanagementinmysqliscialforenhancingsEcurityAndsingsmenting效率databaseoperation.1)usecReateusertoAddusers,指定connectionsourcewith@'localhost'or@'%'。

    哪些因素會影響我可以在MySQL中使用的觸發器數量?哪些因素會影響我可以在MySQL中使用的觸發器數量?May 14, 2025 am 12:08 AM

    mysqldoes notimposeahardlimitontriggers,butacticalfactorsdeterminetheireffactective:1)serverConfiguration impactactStriggerGermanagement; 2)複雜的TriggerSincreaseSySystemsystem load; 3)largertablesslowtriggerperfermance; 4)highConconcConcrencerCancancancancanceTigrignecentign; 5); 5)

    mysql:存儲斑點安全嗎?mysql:存儲斑點安全嗎?May 14, 2025 am 12:07 AM

    Yes,it'ssafetostoreBLOBdatainMySQL,butconsiderthesefactors:1)StorageSpace:BLOBscanconsumesignificantspace,potentiallyincreasingcostsandslowingperformance.2)Performance:LargerrowsizesduetoBLOBsmayslowdownqueries.3)BackupandRecovery:Theseprocessescanbe

    mySQL:通過PHP Web界面添加用戶mySQL:通過PHP Web界面添加用戶May 14, 2025 am 12:04 AM

    通過PHP網頁界面添加MySQL用戶可以使用MySQLi擴展。步驟如下:1.連接MySQL數據庫,使用MySQLi擴展。 2.創建用戶,使用CREATEUSER語句,並使用PASSWORD()函數加密密碼。 3.防止SQL注入,使用mysqli_real_escape_string()函數處理用戶輸入。 4.為新用戶分配權限,使用GRANT語句。

    mysql:blob和其他無-SQL存儲,有什麼區別?mysql:blob和其他無-SQL存儲,有什麼區別?May 13, 2025 am 12:14 AM

    mysql'sblobissuitableForStoringBinaryDataWithInareLationalDatabase,而ilenosqloptionslikemongodb,redis和calablesolutionsolutionsolutionsoluntionsoluntionsolundortionsolunsonstructureddata.blobobobissimplobisslowdeperformberbutslowderformandperformancewithlararengedata;

    mySQL添加用戶:語法,選項和安全性最佳實踐mySQL添加用戶:語法,選項和安全性最佳實踐May 13, 2025 am 12:12 AM

    toaddauserinmysql,使用:createUser'username'@'host'Indessify'password'; there'showtodoitsecurely:1)choosethehostcarecarefullytocon trolaccess.2)setResourcelimitswithoptionslikemax_queries_per_hour.3)usestrong,iniquepasswords.4)Enforcessl/tlsconnectionswith

    MySQL:如何避免字符串數據類型常見錯誤?MySQL:如何避免字符串數據類型常見錯誤?May 13, 2025 am 12:09 AM

    toAvoidCommonMistakeswithStringDatatatPesInMysQl,CloseStringTypenuances,chosethirtightType,andManageEngencodingAndCollat​​ionsEttingSefectery.1)usecharforfixed lengengtrings,varchar forvariable-varchar forbariaible length,andtext/blobforlargerdataa.2 seterters seterters seterters

    See all articles

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    Video Face Swap

    Video Face Swap

    使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

    熱門文章

    熱工具

    SublimeText3漢化版

    SublimeText3漢化版

    中文版,非常好用

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的程式碼編輯器

    SublimeText3 Linux新版

    SublimeText3 Linux新版

    SublimeText3 Linux最新版

    MantisBT

    MantisBT

    Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

    SAP NetWeaver Server Adapter for Eclipse

    SAP NetWeaver Server Adapter for Eclipse

    將Eclipse與SAP NetWeaver應用伺服器整合。