V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
RadishWind
V2EX  ›  问与答

如何把两个不同的 sql 语句用 order by 排序后(表结构相同但是排序方法不同) 然后合并起来?

  •  
  •   RadishWind · 2017-02-25 17:54:16 +08:00 · 2586 次点击
    这是一个创建于 2589 天前的主题,其中的信息可能已经有所发展或是发生改变。
    5 条回复    2017-02-26 09:04:48 +08:00
    loading
        1
    loading  
       2017-02-25 18:07:12 +08:00
    我不擅长 SQL ,所以我都会配合程序处理。
    rockpk008
        2
    rockpk008  
       2017-02-25 18:11:35 +08:00 via iPhone
    有些忘记了, with as 应该可以吧。
    billlee
        3
    billlee  
       2017-02-25 18:27:44 +08:00
    前段时间刚写过类似的,不知道有没有更好的办法

    SELECT ... FROM ((
         SELECT ... FROM ...
         ORDER BY ...
         LIMIT 0, ?
    ) UNION (
         SELECT ... FROM ...
         ORDER BY ...
         LIMIT 0, ?
      )
    ) ORDER BY ... LIMIT ?, ?
    shoaly
        4
    shoaly  
       2017-02-25 19:31:52 +08:00
    拆开逻辑吧
    分别 sql 取到 2 个 数组里面, 然后 数组在合并 在排序.
    否则就算 sql 整在一起 一起喝成写完之后, 过两天就忘记了, 再也没办法维护
    ebony0319
        5
    ebony0319  
       2017-02-26 09:04:48 +08:00 via Android
    增加一个标记位就可以了,最后对标记位排序。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2491 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 15:45 · PVG 23:45 · LAX 08:45 · JFK 11:45
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.