douxiaochun4964 2015-12-30 06:19
浏览 131
已采纳

如何在选择查询中获取行号

i try this query to get row number in selected rows, but the output comes like 23,56,78,.... i need to get 1,2,3 to every selected row. please help me

SET @row=0;
SELECT `table1`.`col1`,`table1`.`col2`,@row:=@row+1
FROM `table1`
LEFT OUTER JOIN `table2` ON `table1`.`col1` = `table2`.`col5`
WHERE `table2`.`col5` IS NOT NULL
GROUP BY `col1` ORDER BY `table1`.`col7` DESC LIMIT 0,10
  • 写回答

2条回答 默认 最新

  • dongzi1209 2015-12-30 06:31
    关注

    Move the query with the ORDER BY clause into a subquery.

    SET @row = 0;
    
    SELECT col1, col2, @row := @row+1
    FROM (SELECT table1.col1, table1.col2
          FROM table1
          LEFT JOIN table2 ON table1.col1 = table2.col5
          WHERE table2.col5 IS NOT NULL
          GROUP BY col1
          ORDER BY table1.col7 DESC
          LIMIT 0, 10) AS subquery
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • duankezong4064 2015-12-30 06:34
    关注

    You can try using an inline view. Use a query that gets the rows you want to return, and then wrap that in parens, and reference that query in the FROM clause of an outer query.

    Something like this:

      SELECT v.`col1`
           , v.`col2` 
           , @row := @row + 1 AS `rn`
        FROM ( SELECT `table1`.`col1`
                    , `table1`.`col2`
                 FROM `table1`
                  ... 
                ORDER BY ...
                LIMIT 10
             ) v
    
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 jsp,如何使用户名输出为中文(语言-javascript)
  • ¥15 PowerBI中如何做到按数值向下取数
  • ¥15 设计quartus maxⅡ :Verilog-FPGA(0
  • ¥15 windows server 2022 datacenter安全策略配置 没有权限问题
  • ¥20 寻找dspace有偿技术支持
  • ¥30 深度学习的模型融合问题
  • ¥20 数电实验Verilog编程
  • ¥15 机器人MATLAB仿真示教占内存过大
  • ¥15 JSR233已经使用但是仍无法将csv数据放到一个list里显示出来,如何解决?
  • ¥15 I350 Gigabit Network