今天也要学习呐 2022-03-18 16:19 采纳率: 68.2%
浏览 51
已结题

想让一个字段的行数作为筛选条件

问题遇到的现象和发生背景

在A表中的payable_amount字段,我希望只要这个字段前10的,也就是在筛选条件里加上只要payable_amount字段前10的条件
不要用LIMIT,因为我其他的字段要全部呢

问题相关代码,请勿粘贴截图
SELECT
  a,b,c,d,e,payable_amount
FROM(
-----------------有问题的部分---------------------
SELECT
  a,b,c,d,e,f,REPLACE(m.money,CONCAT(t.amount,','),'') as payable_amount
FROM
 tblM as m
LEFT JOIN
 tblT as t
ON  t.a= m.a
-----------------有问题的部分---------------------
    ) t
    WHERE t.a IS NOT NULL
)

运行结果及报错内容
我的解答思路和尝试过的方法
我想要达到的结果

在“有问题的部分”里面,希望能加上只要payable_amount字段前10的筛选条件

  • 写回答

4条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-03-18 18:29
    关注

    前10是指总共只取10行出来还是说要按哪些字段分组排序,取每个分组的前10?如果有分组的话是按哪几个字段?
    如果没有分组,那么是可以用order by 加limit的,当然也可以使用开窗函数,比如把你中间那段替换成下面这样

    select * from  (
    SELECT
      a,b,c,d,e,f,REPLACE(m.money,CONCAT(t.amount,','),'') as payable_amount,
    row_number() over(order by REPLACE(m.money,CONCAT(t.amount,','),'') desc) rn
    FROM
     tblM as m
    LEFT JOIN
     tblT as t
    ON  t.a= m.a) xx where rn<=10
    

    如果是要分组取前10,开窗函数里加上 partition by 分组的字段就好了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 3月29日
  • 已采纳回答 3月21日
  • 创建了问题 3月18日

悬赏问题

  • ¥15 wpf界面一直接收PLC给过来的信号,导致UI界面操作起来会卡顿
  • ¥15 运动想象脑电信号数据集.vhdr
  • ¥15 三因素重复测量数据R语句编写,不存在交互作用
  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景