第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

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

標(biāo)簽:
MySQL

最近出现一个很奇怪的MySQL问题,使用不同select语句查询全部数据集居然得到不同的记录数。select * 得到4条记录,select 字段得到的是3条记录。
具体问题可以看下面的查询结果:  
[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   | 
+--------------------+-------+----------+-------------------------------------------------------+ 
查询数据不一致的原因是table_myisam的索引文件损坏了,对应的索引文件table_myisam.MYI与数据文件table_myisam.MYD不一致。select *并不需要遍历每个索引项,只需要获取第一条记录,根据链表顺序访问,因此当前的索引损坏并没有影响到select *的使用。而select uid需要遍历所有索引项,因而只获取到损坏状态,三条索引记录。
   解决方案是使用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可以看到表状态变成正常,使用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) 

點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺(jué)得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫(xiě)下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說(shuō)多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開(kāi)微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消