溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Navicat統(tǒng)計(jì)的行數(shù)和表實(shí)際行數(shù)不一致的問題怎么理解

發(fā)布時(shí)間:2021-12-03 09:01:45 來源:億速云 閱讀:369 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“Navicat統(tǒng)計(jì)的行數(shù)和表實(shí)際行數(shù)不一致的問題怎么理解”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

背景

近期為了保障線上數(shù)據(jù)庫的穩(wěn)定性,我決定針對一些大表的歷史數(shù)據(jù)有計(jì)劃地進(jìn)行備份遷移,但是呢,發(fā)現(xiàn)一個(gè)奇特的現(xiàn)象,Navicat統(tǒng)計(jì)行數(shù)和表自身count統(tǒng)計(jì)數(shù)竟然不一致!?0.0

Navicat

Navicat作為數(shù)據(jù)庫管理工具,在業(yè)界廣受歡迎,先甭管你電腦上現(xiàn)在正在運(yùn)行的Navicat是正版還是盜版(你不說我也知道),不可否認(rèn)的是,在我從事17年從事后端開發(fā)以來,嘗試了很多同類工具,Navicat在功能上完全碾壓其他數(shù)據(jù)庫管理工具,尤其是細(xì)節(jié)方面,在這里不一一列舉了,總之一個(gè)字,就是很好用(不接受反駁,除非你說出來一個(gè)讓我心服口服的工具)。

整個(gè)經(jīng)過

這次大表遷移備份,我的整體思路是:首先用Navicat對庫內(nèi)所有的表按照行數(shù)降序排序,然后選取Top10進(jìn)行遷移備份。但是一如既往細(xì)心的我發(fā)現(xiàn),它界面的統(tǒng)計(jì)行數(shù)竟然和我自己count這張表行數(shù)不一致?!難道要顛覆我對Navicat的認(rèn)可嘛。

Navicat統(tǒng)計(jì)的行數(shù)和表實(shí)際行數(shù)不一致的問題怎么理解

select count(1) from big_table_name;

為什么呢?

這讓我很是詫異,一度以為自己出現(xiàn)了幻覺,再三確認(rèn)自己沒有帶VR眼鏡后,我踏上了尋找答案的征程。我開始思考,Mysql作為一個(gè)數(shù)據(jù)庫,自身肯定就有各個(gè)表的統(tǒng)計(jì),而Navicat只是作為一個(gè)可視化界面,讓數(shù)據(jù)肉眼可見。

Navicat:這鍋我可不背。

為了證實(shí)我的猜想,我查閱了官方文檔及其他相關(guān)資料,果然,MySQL 在 information_schema.TABLES表中息存放了所有表的信息。

select * from information_schema.TABLES;

查看了這張表以后,發(fā)現(xiàn)表里統(tǒng)計(jì)記錄TABLE_ROWS字段的確實(shí)與事實(shí)count不符……

這又是為什么呢?

我又陷入了沉思,帶著疑惑,繼續(xù)翻閱著文檔,突然,看到MySQL官方文檔對TABLE_ROWS的解釋:

The number of rows. Some storage engines, such as MyISAM, store the exact count. For other storage engines, such as InnoDB, this value is an approximation, and may vary from the actual value by as much as 40% to 50%. In such cases, use SELECT COUNT(*) to obtain an accurate count.

看了這段話我頓悟啦,你是不是也明白怎么回事啦。什么?你沒看太明白?好吧,沒關(guān)系,你可能需要通過翻譯軟件的直譯+理解,才懂得其中真正的含義。原來,TABLE_ROWS這個(gè)字段不同存儲引擎的計(jì)數(shù)規(guī)則不一致,比如MyISAM引擎這表存儲TABLE_ROWS存儲的就是精確的行數(shù),而對于其他的存儲引擎,比如 InnoDB,這個(gè)值只是一個(gè)近似值,與實(shí)際值相差40%-50%左右。所以,在這種情況下,我們想要得到一個(gè)準(zhǔn)確的計(jì)數(shù),只能使用 SELECT COUNT(*) 來獲得。

那又如何修正呢?

雖然疑惑得到了解答。但,和我一樣有強(qiáng)迫癥的朋友肯定會問,如何修正這個(gè)值呢?真是知道越多,未知越多,網(wǎng)上說可以通過

Analyze table big_table_name

得以更正這個(gè)數(shù)據(jù),但是我動手執(zhí)行之后發(fā)現(xiàn),并不能更正數(shù)據(jù),且該操作不僅耗時(shí)還會鎖表,并不推薦使用……說到這,我的強(qiáng)迫癥竟然不治自愈了。

“Navicat統(tǒng)計(jì)的行數(shù)和表實(shí)際行數(shù)不一致的問題怎么理解”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI