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

MySQL查詢?nèi)繑?shù)據(jù)集結(jié)果不一致問題解決方案

 更新時間:2012年11月16日 08:53:13   作者:  
最近出現(xiàn)一個很奇怪的MySQL問題,使用不同select語句查詢?nèi)繑?shù)據(jù)集居然得到不同的記錄數(shù)

最近出現(xiàn)一個很奇怪的MySQL問題,使用不同select語句查詢?nèi)繑?shù)據(jù)集居然得到不同的記錄數(shù)。select * 得到4條記錄,select 字段得到的是3條記錄。
具體問題可以看下面的查詢結(jié)果:  
[sql]
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,才找到問題的所在。
[sql]
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的索引文件損壞了,對應的索引文件table_myisam.MYI與數(shù)據(jù)文件table_myisam.MYD不一致。select *并不需要遍歷每個索引項,只需要獲取第一條記錄,根據(jù)鏈表順序訪問,因此當前的索引損壞并沒有影響到select *的使用。而select uid需要遍歷所有索引項,因而只獲取到損壞狀態(tài),三條索引記錄。
   解決方案是使用repair table進行表索引的修復。
[sql]
mysql> repair table table_myisam; 
+--------------------+--------+----------+----------+ 
| Table  | Op | Msg_type | Msg_text | 
+--------------------+--------+----------+----------+ 
| qitai.table_myisam | repair | status   | OK   | 
+--------------------+--------+----------+----------+ 
1 row in set (0.00 sec) 
修復后使用check table可以看到表狀態(tài)變成正常,使用select *與select uid都能獲取到4條記錄。
[sql]
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編碼方式讓它支持中文(gbk或者utf8)

    查看修改mysql編碼方式讓它支持中文(gbk或者utf8)

    MySQL的默認編碼是Latin1,不支持中文,要支持中文需要把數(shù)據(jù)庫的默認編碼修改為gbk或者utf8,真的是很麻煩啊,不過本文提供了詳細的修改教程,感興趣的你可不要走開啊,希望本文對你有所幫助
    2013-01-01
  • MySQL數(shù)據(jù)庫數(shù)據(jù)視圖

    MySQL數(shù)據(jù)庫數(shù)據(jù)視圖

    這篇文章主要介紹了MySQL數(shù)據(jù)庫數(shù)據(jù)視圖,視圖是原始數(shù)據(jù)庫數(shù)據(jù)的一種變換,是查看表中數(shù)據(jù)的另外一種方式,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-08-08
  • 詳解MySQL誤操作后怎樣進行數(shù)據(jù)恢復

    詳解MySQL誤操作后怎樣進行數(shù)據(jù)恢復

    在大家日常操作數(shù)據(jù)庫時候難免會因為“大意”而誤操作,那么誤操作后怎樣進行數(shù)據(jù)恢復呢,下面跟著小編一起來學習學習。
    2016-08-08
  • mysql查看用戶權(quán)限常用的方法

    mysql查看用戶權(quán)限常用的方法

    MySQL是一個流行的開源關系型數(shù)據(jù)庫管理系統(tǒng),具有強大的功能和靈活的用戶權(quán)限控制機制,這篇文章主要給大家介紹了關于mysql查看用戶權(quán)限常用的方法,需要的朋友可以參考下
    2024-03-03
  • 一文了解MySQL的四大子查詢

    一文了解MySQL的四大子查詢

    本文主要介紹了一文了解MySQL的四大子查詢,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • MySQL into_Mysql中replace與replace into用法案例詳解

    MySQL into_Mysql中replace與replace into用法案例詳解

    這篇文章主要介紹了MySQL into_Mysql中replace與replace into用法案例詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • MySQL中查詢字段為空或者為null的方法

    MySQL中查詢字段為空或者為null的方法

    這篇文章主要介紹了MySQL中查詢字段為空或者為null的方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • mysql全量備份和快速恢復的方法整理

    mysql全量備份和快速恢復的方法整理

    在本篇文章里小編給各位整理的是關于mysql全量備份和快速恢復的方法整理內(nèi)容,需要的朋友們可以參考下。
    2020-03-03
  • MySQL5.5.21安裝配置教程(win7)

    MySQL5.5.21安裝配置教程(win7)

    這篇文章主要以圖文結(jié)合的方式介紹了Win7系統(tǒng)下安裝MySQL5.5.21的具體過程,感興趣的小伙伴們可以參考一下
    2016-06-06
  • MySQL開放遠程連接權(quán)限的兩種方法

    MySQL開放遠程連接權(quán)限的兩種方法

    在我們使用mysql數(shù)據(jù)庫時,有時我們的程序與數(shù)據(jù)庫不在同一機器上,這時我們需要遠程訪問數(shù)據(jù)庫,下面這篇文章主要給大家介紹了關于MySQL開放遠程連接權(quán)限的兩種方法,需要的朋友可以參考下
    2022-06-06

最新評論