回覆列表
  • 1 # 何以笙丶丶

    對於mysql來說,有三種鎖的級別:頁級、表級、行級

    頁級的典型代表引擎為bdb。

    表級的典型代表引擎為myisam,memory以及很久以前的isam。

    行級的典型代表引擎為innodb。

    -我們實際應用中用的最多的就是行鎖。

    行級鎖的優點如下:

    1)、當很多連線分別進行不同的查詢時減小lock狀態。

    2)、如果出現異常,可以減少資料的丟失。因為一次可以只回滾一行或者幾行少量的資料。

    行級鎖的缺點如下:

    1)、比頁級鎖和表級鎖要佔用更多的記憶體。

    2)、進行查詢時比頁級鎖和表級鎖需要的i/o要多,所以我們經常把行級鎖用在寫操作而不是讀操作。

    3)、容易出現死鎖。

    對於寫鎖定如下:

    1)、如果表沒有加鎖,那麼對其加寫鎖定。

    2)、否則,那麼把請求放入寫鎖佇列中。

    對於讀鎖定如下:

    1)、如果表沒有加寫鎖,那麼加一個讀鎖。

    2)、否則,那麼把請求放到讀鎖佇列中。

    當然我們可以分別用low_priority以及high_priority在寫和讀操作上來改變這些行為。

    如果想要在一個表上做大量的insert和select操作,但是並行的插入卻不可能時,可以將記錄插入到臨時表中,然後定期將臨時表中的資料更新到實際的表裡。可以用以下命令實現:

    mysql>locktablesreal_tablewrite,insert_tablewrite;

    mysql>insertintoreal_tableselect*frominsert_table;

    mysql>truncatetableinsert_table;

    mysql>unlocktables;

    innodb使用行級鎖,bdb使用頁級鎖。對於innodb和bdb儲存引擎來說,是可能產生死鎖的。這是因為innodb會自動捕獲行鎖,bdb會在執行sql語句時捕獲頁鎖的,而不是在事務的開始就這麼做。

    行級鎖的優點有:

    在很多執行緒請求不同記錄時減少衝突鎖。

    事務回滾時減少改變資料。

    使長時間對單獨的一行記錄加鎖成為可能。

    行級鎖的缺點有:

    比頁級鎖和表級鎖消耗更多的記憶體。

    當在大量表中使用時,比頁級鎖和表級鎖更慢,因為他需要請求更多的所資源。

    當需要頻繁對大部分資料做groupby操作或者需要頻繁掃描整個表時,就明顯的比其它鎖更糟糕。

    使用更高層的鎖的話,就能更方便的支援各種不同的型別應用程式,因為這種鎖的開銷比行級鎖小多了。

    表級鎖在下列幾種情況下比頁級鎖和行級鎖更優越:

    很多操作都是讀表。

    updatetbl_namesetcolumn=valuewhereunique_key_col=key_value;

    deletefromtbl_namewhereunique_key_col=key_value;

    select和insert語句併發的執行,但是隻有很少的update和delete語句。

    很多的掃描表和對全表的groupby操作,但是沒有任何寫表。

    表級鎖和行級鎖或頁級鎖之間的不同之處還在於:

    將同時有一個寫和多個讀的地方做版本(例如在mysql中的併發插入)。也就是說,資料庫/表支援根據開始訪問資料時間點的不同支援各種不同的試圖。其它名有:時間行程,寫複製,或者是按需複製。

    複製程式碼程式碼如下:

    //執行sql語句鎖掉stat_num表

    $sql="locktables表名write";//表的write鎖定,阻塞其他所有mysql查詢程序

    mysql_query($sql);

    //執行更新或寫入操作

    $sql="updatestat_numset`correct_num`=`correct_num`+1wherestat_date="{$cur_date}"";

    mysql_query($sql);

    //當前請求的所有寫操作做完後,執行解鎖sql語句

    $sql="unlocktables";

    mysql_query($sql);

  • 2 # 使用者7878186475180

    內部臨時表在SQL語句的最佳化過程中扮演著非常重要的角色, MySQL中的很多操作都要依賴於內部臨時表來進行最佳化。

    但是使用內部臨時表需要建立表以及中間資料的存取代價,所以使用者在寫SQL語句的時候應該儘量的去避免使用臨時表。

  • 中秋節和大豐收的關聯?
  • 妻子寫給丈夫的廉潔寄語中被寄語人稱謂是寫丈夫嗎?