pujitan978 2022-11-28 15:23 采纳率: 28.6%
浏览 78
已结题

检索带order by 非常慢

postgres 数据库分表查询,按create_time 查询非常慢,5分钟都检索不出数据。
删除order by 或者 把create_time改为 code 就很快。每个表的数据1000万行。

表:
20221127表1 20221128表2 t20221130表3
时间表 中 create_time(timestamp) 和 code(string)有索引

select *
FROM
( SELECT * FROM 20221127表1 UNION ALL SELECT * FROM 20221128表2 UNION ALL SELECT * FROM t20221130表3 ) AS PP
where
PP.create_time>= '2022-11-16 00:00:00.0'
AND PP.create_time<= '2022-11-27 00:00:00.0'
AND PP.code = 'AAAA'
**order by PP .create_time desc **
OFFSET 0
LIMIT 10

  • 写回答

4条回答 默认 最新

  • 游一游走一走 2022-11-28 15:33
    关注
    获得3.75元问题酬金

    改写你的SQL语句,每个表先用create_time>= '2022-11-16 00:00:00.0' and create_time<= '2022-11-27 00:00:00.0' and code = 'AAAA' 然后再union all 试试看

    SELECT 
        *
    FROM
        (SELECT 
            *
        FROM
            csdn_mobile
        WHERE
            create_time >= '2022-11-16 00:00:00.0'
                AND create_time <= '2022-11-27 00:00:00.0'
                AND code = 'AAAA' UNION ALL SELECT 
            *
        FROM
            csdn_mobile
        WHERE
            create_time >= '2022-11-16 00:00:00.0'
                AND create_time <= '2022-11-27 00:00:00.0'
                AND code = 'AAAA' UNION ALL SELECT 
            *
        FROM
            csdn_mobile
        WHERE
            create_time >= '2022-11-16 00:00:00.0'
                AND create_time <= '2022-11-27 00:00:00.0'
                AND code = 'AAAA') AS t
    ORDER BY t.create_time DESC
    OFFSET 0 LIMIT 10
    
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 12月6日
  • 创建了问题 11月28日

悬赏问题

  • ¥15 关于#网络安全#的问题:求ensp的网络安全,不要步骤要完成版文件
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥20 使用Photon PUN2解决游戏得分同步的问题
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据
  • ¥15 Vue3 大型图片数据拖动排序
  • ¥15 Centos / PETGEM