LongStaying 2019-04-08 14:30 采纳率: 83.3%
浏览 409
已采纳

关于Mysql的Limit转换为TOP语句过程中出现语法错误问题

mysql:

    select ordersitem.flowerid,flowername,sum(ordersitem.flowernum) as totalnum,orderdate,flowerunit 
    from flower,ordersitem,orders 
    where flower.flowerid=ordersitem.flowerid 
        and orders.id=ordersitem.ordersid 
    group by flowerid 
    order by totalnum desc 
    limit " + (pageNow - 1) * pageSize + "," + pageSize

然后转为我的想法是先将:

select ordersitem.flowerid,flowername,sum(ordersitem.flowernum) 
as totalnum,orderdate,flowerunit 
from flower,ordersitem,orders 
where flower.flowerid=ordersitem.flowerid 
and orders.id=ordersitem.ordersid 
group by flowerid order by totalnum desc

作为一个结果表,然后对这个结果表进行top操作:

SELECT top 2 * FROM (
select ordersitem.flowerid,flowername,sum(ordersitem.flowernum) 
as totalnum,orderdate,flowerunit 
from flower,ordersitem,orders 
where flower.flowerid=ordersitem.flowerid 
and orders.id=ordersitem.ordersid 
group by ordersitem.flowerid,flowername,orderdate,flowerunit 
)
WHERE ordersitem.flowerid NOT in (

SELECT top 0 flowerid FROM(
select ordersitem.flowerid,flowername,sum(ordersitem.flowernum) 
as totalnum,orderdate,flowerunit 
from flower,ordersitem,orders 
where flower.flowerid=ordersitem.flowerid 
and orders.id=ordersitem.ordersid 
group by ordersitem.flowerid,flowername,orderdate,flowerunit 
)
)
order by totalnum desc

然后就是一直语法错误,于是我就把下面分页的部分去掉了:

SELECT top 2 * FROM (
select ordersitem.flowerid,flowername,sum(ordersitem.flowernum) 
as totalnum,orderdate,flowerunit 
from flower,ordersitem,orders 
where flower.flowerid=ordersitem.flowerid 
and orders.id=ordersitem.ordersid 
group by ordersitem.flowerid,flowername,orderdate,flowerunit 
)

测试了一下这样的写法,还是说语法有错误,不知道错误在哪里....很迷茫,我还要不要继续从事计算机? 手动滑稽, 请大佬帮忙看看....

  • 写回答

4条回答 默认 最新

  • 聂晓宁_Cherry 2019-04-08 14:47
    关注

    可以尝试一下下面的SQL:
    SELECT top 2 t.* FROM (
    select ordersitem.flowerid,flowername,orderdate,flowerunit,sum(ordersitem.flowernum) as totalnum
    from flower,ordersitem,orders
    where flower.flowerid=ordersitem.flowerid
    and orders.id=ordersitem.ordersid
    group by ordersitem.flowerid,flowername,orderdate,flowerunit ) t
    order by t.totalnum desc
    ;

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

报告相同问题?

悬赏问题

  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?