zoukankan      html  css  js  c++  java
  • Sql:多行合并一行以及多条数据取时间最早的那条

    有两个导数据的需求,
    1、一张表里面每一个订单号可能对应多条数据,每个单号返回时间最早的那条。

    2、根据条件查询某个字段并按照逗号,合并在一起。

    表类似结构如下:

    第一条sql:
    select c.Id,c.OrderNum, c.CreateTime FROM (select t.*,row_number() over(partition by t.OrderNum order by t.CreateTime ) rn  from Payinfo t WHERE t.OrderNum IN('20160906025229','20160905006031','20160905016570')) c WHERE rn = 1;

    执行效果如下:


    主要知识点:over partition by
    over partition  by关键字是分析性函数的一部分,它和聚合函数不同的地方在于它能返回一个分组中的多条记录,常用于给结果集分组,如果没有指定那么它把整个结果集作为一个分组 。

    Group by 与 over partition by都可以实现分组统计功能.

    Group by 根据一列或者多列的值或表达式将选定的行进行一个摘要分组,每一个分组只返回一行。

    第二条sql:


    SELECT TOP 1  data=STUFF((SELECT ','+ CAST(id AS VARCHAR(10))  FROM Payinfo t WHERE OrderNum IN('20160906025229','20160905006031')  FOR XML PATH('')), 1, 1, '')
    FROM Payinfo t1

    执行效果如下:

    3

    主要知识点:FOR XML PATH
    将查询结果集以XML形式展现,有了它我们可以简化我们的查询语句实现一些以前可能需要借助函数活存储过程来完成的工作。

    有关FOR XML PATH更多知识,我觉得下面这篇文章讲的很好:
    灵活运用 SQL SERVER FOR XML PATH

  • 相关阅读:
    备忘:java在cmd中编译运行
    Java基础学习 —— 对象的克隆
    将博客搬至CSDN
    jenkins节点管理中没有默认没有Launch agent via Java Web Start
    postman 集成ci
    postman初级使用
    jmeter分布式压测实践及踩坑记录(linux压力机)
    jmeter监控服务器cpu、内存等
    jmeter跨线程组传递token实践
    初识jmeter
  • 原文地址:https://www.cnblogs.com/1024zy/p/6020874.html
Copyright © 2011-2022 走看看