美高梅开户-美高梅官方网站开户

您的位置:美高梅开户 > 数据库 > 多行统生机勃勃大器晚成行以致多条数据取时间

多行统生机勃勃大器晚成行以致多条数据取时间

发布时间:2020-01-01 16:27编辑:数据库浏览(74)

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

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

    表类似结构如下:

    图片 1

    第一条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;

    执行效果如下:

    图片 2
    主要知识点: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

    本文由美高梅开户发布于数据库,转载请注明出处:多行统生机勃勃大器晚成行以致多条数据取时间

    关键词: 美高梅开户

上一篇:美高梅开户:Mysql中UNION用法与排序

下一篇:没有了