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

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

使用 PDO 獲取記錄在 SQL 結果中的位置

使用 PDO 獲取記錄在 SQL 結果中的位置

PHP
搖曳的薔薇 2023-05-26 17:31:07
當直接在 SQL 中注入時,此查詢有效。有任何替代方法可以使它與一個查詢一起使用,而不是兩個嗎?$Get= $db->select("SET @row_number = 0; SELECT (@row_number:=@row_number + 1) AS num, score, points, connected FROM info WHERE id='$id' ORDER BY score DESC");如果我SET @row_number = 0;在 PHP 中刪除它可以工作,但它不會給我輸出num..它保持空白
查看完整描述

1 回答

?
侃侃無極

TA貢獻2051條經驗 獲得超10個贊

如果您使用的是 MySQL 8+,則只需使用ROW_NUMBER():


SELECT

    ROW_NUMBER() OVER (ORDER BY score DESC) num,

    score,

    points,

    connected

FROM info

WHERE id = ?

ORDER BY score DESC;

如果你想要一個可以在不支持 MySQL 的早期版本上工作的版本ROW_NUMBER,那么你可以使用相關的子查詢:


SELECT

    (SELECT COUNT(*) FROM info i2 WHERE i2.score >= i1.score) num

    score,

    points,

    connected

FROM info i1

WHERE id = ?

ORDER BY score DESC;

上述查詢只有在每個分數都是唯一的情況下才能正常工作,也就是說,沒有重復的分數。


查看完整回答
反對 回復 2023-05-26
  • 1 回答
  • 0 關注
  • 133 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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