首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    复杂sql分组查询 ( pivot)

    一个数据表里面字段有年、月、日、金额、支付方式等字段,然后现在想写个sql语句,把每一天的每种支付方式金额(支付方式有多重)排在同一行, 最后在增加一列小计当前的所有支付方式的金额。...如下图: 原sql查询出来的结果是这样的: ?...这可为难了我了,简单的增删改查左右链接sql语句我还会写,这个稍微复杂一点我就不知道如何下手了。该怎么分组,然后把行增加为列呢? 去找度娘搜的时候,都不知道怎么描述自己的想搜的关键字。...最后找了一位sql高手同学帮忙解决了这个问题, 人家只是一句简单的sql语句就把我的需求给实现了,实在是让我佩服!这个pivot关键是什么东东,我还第一次看见,从来没用过,这么强大!...( select * from #temp) AS t PIVOT (SUM(amount) FOR [PayType] IN ( [711], [BankIn],[iTunesHK])) AS t;

    3.5K30

    sqlserver pivot函数(oracle行列转换函数)

    Select 'Demon' ,'English',round(60+40*rand(),0) 这张表的呈现形式如下: 通过行列转换函数: SELECT * FROM Students PIVOT...count、sum、max、min、avg,无论是用哪一个聚集函数都代表着不同的意义,我这里用的MAX,针对这里聚集函数的使用我在后面的篇章中有讲到–> 点击打开) 呈现形式如下: 注:pivot...from 也就通过了,最终结果也没有报错,其实正规来讲,如果select 语句比较复杂,这种写法可能会报错的,下面有一种保险一点的写法: SELECT * FROM ( –这里写复杂的sql...查询语句 ) a PIVOT(–此次省略相关code) AS PVT 之前的例子可以这样写: SELECT * FROM ( SELECT * FROM Students )...a PIVOT(MAX(SCORE) FOR Subject IN(Chiness,Math,English) ) AS PVT 最终的执行结果是一样的!

    2.7K30

    Oracle行转列,pivot函数和unpivot函数

    Oracle 测试数据 行转列 以下一般是行转列的正常需求: image.png 要完成该需求,可以用两种方法 一是:CASE WHEN+GROUP BY 二是PIVOT函数 我们用第二种 SELECT...* FROM TEST_PIVOT PIVOT(SUM(SCORE) FOR COURSE IN('英语','数学','语文'))B image.png 这些中文字段名比较刺眼,王五的 英语列和 数学列也为空不好看...我们这边强壮下sql SELECT NAME, NVL(ENGLISH,0) AS ENGLISH, NVL(MARTH,0) AS MARTH, NVL(LANGUAGES,0) AS LANGUAGES...FROM TEST_PIVOT PIVOT(SUM(SCORE) FOR COURSE IN('英语' AS ENGLISH ,'数学' AS MARTH,'语文' AS LANGUAGES)) image.png...image.png 列转行 image.png 要完成该需求,可以用两种方法 一是:UNION ALL 二是UMPIVOT函数 我们用第二种 SELECT name,COURSE,SCORE FROM TEST_PIVOT1

    83130
    领券