MySQL中查詢數(shù)據(jù)不一致怎么辦

這篇文章主要介紹MySQL中查詢數(shù)據(jù)不一致怎么辦,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

10年積累的網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作經(jīng)驗(yàn),可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先做網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有永登免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

最近出現(xiàn)一個(gè)很奇怪的MySQL問題,使用不同select語句查詢?nèi)繑?shù)據(jù)集居然得到不同的記錄數(shù).select * 得到4條記錄,select 字段得到的是3條記錄.
    具體問題可以看下面的查詢結(jié)果:
    mysql> select * from table_myisam;
    +----------+-------+-----------+------+
    | datetime | uid   | content   | type |
    +----------+-------+-----------+------+
    |        1 | uid_1 | content_1 |    1 |
    |        2 | uid_2 | content_2 |    1 |
    |        4 | uid_4 | content_4 |    1 |
    |        3 | uid_3 | content_3 |    1 |
    +----------+-------+-----------+------+
    4 rows in set (0.00 sec)
    mysql> select uid from table_myisam;
    +-------+
    | uid   |
    +-------+
    | uid_1 |
    | uid_2 |
    | uid_4 |
    +-------+
    3 rows in set (0.00 sec)
    通過select uid只得到3行記錄,丟失了其中uid='uid_3‘的記錄.本來百思不得其解,后來在同事的提醒下使用了check table,才找到問題的所在.
    mysql> check table table_myisam;
    +--------------------+-------+----------+-------------------------------------------------------+
    | Table              | Op    | Msg_type | Msg_text                                              |
    +--------------------+-------+----------+-------------------------------------------------------+
    | qitai.table_myisam | check | warning  | 1 client is using or hasn't closed the table properly |
    | qitai.table_myisam | check | warning  | Size of indexfile is: 2049      Should be: 2048       |
    | qitai.table_myisam | check | error    | Found 3 keys of 4                                     |
    | qitai.table_myisam | check | error    | Corrupt                                               |
    +--------------------+-------+----------+-------------------------------------------------------+
    查詢數(shù)據(jù)不一致的原因是table_myisam的索引文件損壞了,對應(yīng)的索引文件table_myisam.MYI與數(shù)據(jù)文件 table_myisam.MYD不一致.select *并不需要遍歷每個(gè)索引項(xiàng),只需要獲取第一條記錄,根據(jù)鏈表順序訪問,因此當(dāng)前的索引損壞并沒有影響到select *的使用.而select uid需要遍歷所有索引項(xiàng),因而只獲取到損壞狀態(tài),三條索引記錄.
    解決方案是使用repair table進(jìn)行表索引的修復(fù).
    mysql> repair table table_myisam;
    +--------------------+--------+----------+----------+
    | Table              | Op     | Msg_type | Msg_text |
    +--------------------+--------+----------+----------+
    | qitai.table_myisam | repair | status   | OK       |
    +--------------------+--------+----------+----------+
    1 row in set (0.00 sec)
    修復(fù)后使用check table可以看到表狀態(tài)變成正常,使用select *與select uid都能獲取到4條記錄.
    mysql> check table table_myisam;
    +--------------------+-------+----------+----------+
    | Table              | Op    | Msg_type | Msg_text |
    +--------------------+-------+----------+----------+
    | qitai.table_myisam | check | status   | OK       |
    +--------------------+-------+----------+----------+
    1 row in set (0.00 sec

以上是“MySQL中查詢數(shù)據(jù)不一致怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

當(dāng)前題目:MySQL中查詢數(shù)據(jù)不一致怎么辦
分享路徑:http://www.muchs.cn/article8/ghpdop.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化Google、網(wǎng)站導(dǎo)航建站公司、軟件開發(fā)、做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)