欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql 維護(hù)常用命令

 更新時間:2009年11月30日 19:39:00   作者:  
需要維護(hù)mysql數(shù)據(jù)庫的朋友可以參考下。
Analyze Table

MySQL 的Optimizer(優(yōu)化元件)在優(yōu)化SQL語句時,首先需要收集一些相關(guān)信息,其中就包括表的cardinality(可以翻譯為“散列程度”),它表示某個索引對應(yīng)的列包含多少個不同的值——如果cardinality大大少于數(shù)據(jù)的實際散列程度,那么索引就基本失效了。
我們可以使用SHOW INDEX語句來查看索引的散列程度:

SHOW INDEX FROM PLAYERS;

TABLE KEY_NAME COLUMN_NAME CARDINALITY
------- -------- ----------- -----------
PLAYERS PRIMARY PLAYERNO 14

因為此時PLAYER表中不同的PLAYERNO數(shù)量遠(yuǎn)遠(yuǎn)多于14,索引基本失效。
下面我們通過Analyze Table語句來修復(fù)索引:

ANALYZE TABLE PLAYERS;
SHOW INDEX FROM PLAYERS;
結(jié)果是:
TABLE KEY_NAME COLUMN_NAME CARDINALITY
------- -------- ----------- -----------
PLAYERS PRIMARY PLAYERNO 1000

此時索引已經(jīng)修復(fù),查詢效率大大提高。

需要注意的是,如果開啟了binlog,那么Analyze Table的結(jié)果也會寫入binlog,我們可以在analyze和table之間添加關(guān)鍵字local取消寫入。

Checksum Table

數(shù)據(jù)在傳輸時,可能會發(fā)生變化,也有可能因為其它原因損壞,為了保證數(shù)據(jù)的一致,我們可以計算checksum(校驗值)。
使用MyISAM引擎的表會把checksum存儲起來,稱為live checksum,當(dāng)數(shù)據(jù)發(fā)生變化時,checksum會相應(yīng)變化。
在執(zhí)行Checksum Table時,可以在最后指定選項qiuck或是extended;qiuck表示返回存儲的checksum值,而extended會重新計算checksum,如果沒有指定選項,則默認(rèn)使用extended。

Optimize Table

經(jīng)常更新數(shù)據(jù)的磁盤需要整理碎片,數(shù)據(jù)庫也是這樣,Optimize Table語句對MyISAM和InnoDB類型的表都有效。
如果表經(jīng)常更新,就應(yīng)當(dāng)定期運行Optimize Table語句,保證效率。
與Analyze Table一樣,Optimize Table也可以使用local來取消寫入binlog。

Check Table

數(shù)據(jù)庫經(jīng)??赡苡龅藉e誤,譬如數(shù)據(jù)寫入磁盤時發(fā)生錯誤,或是索引沒有同步更新,或是數(shù)據(jù)庫未關(guān)閉MySQL就停止了。
遇到這些情況,數(shù)據(jù)就可能發(fā)生錯誤:
Incorrect key file for table: ' '. Try to repair it.
此時,我們可以使用Check Table語句來檢查表及其對應(yīng)的索引。
譬如我們運行
CHECK TABLE PLAYERS;

結(jié)果是
TABLE OP MSG_TYPE MSG_TEXT
-------------- ----- -------- --------
TENNIS.PLAYERS check status OK

MySQL會保存表最近一次檢查的時間,每次運行check table都會存儲這些信息:

執(zhí)行
SELECT TABLE_NAME, CHECK_TIME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_NAME = 'PLAYERS'
AND TABLE_SCHEMA = 'TENNIS';

結(jié)果是

TABLE_NAME CHECK_TIME
---------- -------------------
PLAYERS 2006-08-21 16:44:25

Check Table還可以指定其它選項:
UPGRADE:用來測試在更早版本的MySQL中建立的表是否與當(dāng)前版本兼容。
QUICK:速度最快的選項,在檢查各列的數(shù)據(jù)時,不會檢查鏈接(link)的正確與否,如果沒有遇到什么問題,可以使用這個選項。
FAST:只檢查表是否正常關(guān)閉,如果在系統(tǒng)掉電之后沒有遇到嚴(yán)重問題,可以使用這個選項。
CHANGED:只檢查上次檢查時間之后更新的數(shù)據(jù)。
MEDIUM:默認(rèn)的選項,會檢查索引文件和數(shù)據(jù)文件之間的鏈接正確性。
EXTENDED:最慢的選項,會進(jìn)行全面的檢查。

Repair Table

用于修復(fù)表,只對MyISAM和ARCHIVE類型的表有效。
這條語句同樣可以指定選項:
QUICK:最快的選項,只修復(fù)索引樹。
EXTENDED:最慢的選項,需要逐行重建索引。
USE_FRM:只有當(dāng)MYI文件丟失時才使用這個選項,全面重建整個索引。

與Analyze Table一樣,Repair Table也可以使用local來取消寫入binlog。

相關(guān)文章

  • mysql主從復(fù)制配置過程

    mysql主從復(fù)制配置過程

    網(wǎng)站面臨大流量的情況下,數(shù)據(jù)庫讀寫成了性能瓶頸。除了使用多級緩存外,進(jìn)行數(shù)據(jù)讀寫分離,也是提高網(wǎng)站承載能力重要的手段。本文介紹mysql讀寫分離、mysql主從復(fù)制配置過程。
    2020-09-09
  • 詳解MySQL事務(wù)的ACID如何實現(xiàn)

    詳解MySQL事務(wù)的ACID如何實現(xiàn)

    事務(wù)(Transaction)是并發(fā)控制的基本單位,所謂的事務(wù)呢,它是一個操作序列,這些操作要么都執(zhí)行,要么都不執(zhí)行,它是一個不可分割的工作單位,本文給大家詳細(xì)介紹了MySQL事務(wù)的ACID如何實現(xiàn),需要的朋友可以參考下
    2023-10-10
  • MySQL 替換某字段內(nèi)部分內(nèi)容的UPDATE語句

    MySQL 替換某字段內(nèi)部分內(nèi)容的UPDATE語句

    至于字段內(nèi)部分內(nèi)容:比如替換標(biāo)題里面的產(chǎn)品價格,接下來為你詳細(xì)介紹下UPDATE語句的寫法,感興趣的你可以參考下哈,希望可以幫助到你
    2013-03-03
  • MySQL DISTINCT 的基本實現(xiàn)原理詳解

    MySQL DISTINCT 的基本實現(xiàn)原理詳解

    這篇文章主要介紹了MySQL DISTINCT 的基本實現(xiàn)原理詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • mysql5.6 主從復(fù)制同步詳細(xì)配置(圖文)

    mysql5.6 主從復(fù)制同步詳細(xì)配置(圖文)

    這篇文章主要介紹了mysql5.6 主從復(fù)制同步詳細(xì)配置,但不是很詳細(xì)推薦大家看下腳本之家以前的文章,需要的朋友可以參考下
    2016-04-04
  • 基于Php mysql存儲過程的詳解

    基于Php mysql存儲過程的詳解

    本篇文章是對Php中的mysql存儲過程進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • MySql二進(jìn)制連接方式詳解

    MySql二進(jìn)制連接方式詳解

    這篇文章主要介紹了MySql二進(jìn)制連接方式詳解的相關(guān)資料,需要的朋友可以參考下
    2016-05-05
  • MySQL InnoDB架構(gòu)的相關(guān)總結(jié)

    MySQL InnoDB架構(gòu)的相關(guān)總結(jié)

    InnoDB存儲引擎架構(gòu)作為MySQL最常用的存儲引擎,每個后端程序員都應(yīng)有所了解,本文將具體講述MySQL InnoDB架構(gòu)的相關(guān)知識,感興趣的朋友可以參考下
    2021-05-05
  • mysql啟動服務(wù)報1058錯誤的解決方法

    mysql啟動服務(wù)報1058錯誤的解決方法

    這篇文章主要介紹了mysql啟動服務(wù)報1058錯誤的解決方法,需要的朋友可以參考下
    2014-03-03
  • 一條sql語句完成MySQL去重留一

    一條sql語句完成MySQL去重留一

    在使用mysql時,有時需要查詢出某個字段不重復(fù)的記錄,雖然mysql提供 有distinct這個關(guān)鍵字來過濾掉多余的重復(fù)記錄只保留一條,但往往只用它來返回不重復(fù)記錄的條數(shù),而不是用它來返回不重記錄的所有值。
    2017-12-12

最新評論