亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

PDO行計數

PDO行計數

MYYA 2019-06-14 10:31:34
PDO行計數這里有許多相互矛盾的說法。在PHP中使用PDO進行計數的最佳方法是什么?在使用PDO之前,我只是簡單地mysql_num_rows.fetchAll這是我不想要的東西,因為有時我可能要處理大型數據集,所以對我的使用不好。你有什么意見建議?
查看完整描述

3 回答

?
拉丁的傳說

TA貢獻1789條經驗 獲得超8個贊

$sql = "SELECT count(*) FROM `table` WHERE foo = bar"; $result = $con->prepare($sql); $result->execute();
 $number_of_rows = $result->fetchColumn();

這不是最優雅的方法,而且還需要額外的查詢。

PDOPDOStatement::rowCount(),這顯然是在MySQL工作。好痛啊。

來自PDO醫生:

對于大多數數據庫,PDOStatement:rowCount()不返回受SELECT語句影響的行數。相反,使用PDO:query()發出一個SELECT(*)語句,其謂詞與預期的SELECT語句相同,然后使用PDOStatement:getchColumn()檢索將要返回的行數。然后,應用程序可以執行正確的操作。

編輯:上面的代碼示例使用了一個準備好的語句,在許多情況下,這對于計數行可能是不必要的,因此:

$nRows = $pdo->query('select count(*) from blah')->fetchColumn(); echo $nRows;


查看完整回答
反對 回復 2019-06-14
?
小怪獸愛吃肉

TA貢獻1852條經驗 獲得超1個贊

正如我在前面寫的對類似問題的回答,唯一的原因mysql_num_rows()之所以起作用,是因為它在內部獲取所有行以提供信息,即使在您看來它并不像這樣。

因此,在PDO中,您的選擇是:

  1. 使用MySQL的

    FOUND_ROWS()

    功能。
  2. 使用PDO

    fetchAll()

    函數將所有行提取到數組中,然后使用

    count()

    在上面。
  3. 執行額外的查詢

    SELECT COUNT(*)

    ,如Karim79所示。


查看完整回答
反對 回復 2019-06-14
  • 3 回答
  • 0 關注
  • 584 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號