簡體   English   中英

如何從mysql表中獲取總行數?

[英]how to get total number of rows from mysql table?

我正在編寫用於從mysql表(存儲引擎:InnoDB)中獲取記錄總數的代碼,並將其顯示在前端。 我為此使用COUNT(id),如下所示:

SELECT COUNT(id) AS total_count FROM my_table_name

但是我的總計數減少了6行,即,我總共有73條記錄,但總計數卻只有67條記錄。 我在尋找其他解決方案時,發現了如下解決方案:

SHOW TABLE STATUS FROM my_table_name;

但是它會拋出mysql訪問被拒絕的錯誤,例如“用戶'my_user_name'@'localhost'對數據庫'my_table_name'的訪問被拒絕”。 誰能告訴我如何實現這一目標。 提前致謝。

您確定您的表有73條記錄嗎? 還是只看了最高的ID? 中間可能有一些丟失的ID(已刪除)。 該查詢看起來很好,它應該可以工作。 請在phpMyAdmin中再次檢查

如果使用參數*調用,mysql count函數將返回所有行,如下所示

select count(*) as total from myTable

但是如果您提供表的任何列名稱,例如

 select count(id) as total from myTable

那么只會返回id字段不為NULL的那些行的計數。 因此,您的某些行的ID字段可能為NULL ,這就是查詢返回的行數少於實際的原因。

SELECT COUNT(*) AS total_count FROM my_table_name

也許並非所有行都有id

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM