oracle 行转列

news/2024/11/18 2:20:43/

第一个是max(decode( 两个函数一起应用 的行转列(oracle)

第二个是 case when的 行转列(mysql oracle 都可以 (好像))

两者需要注意的
这里面 的group by 参数 是和函数一样的数据 不能有不一致的数据 比如说 主键id 主键ID是这几行数据都不一样的 加上去之后 就会把原来几条都查出来

SELECT 
max(decode(hs.PAY_TAB_CODE, '235', hs.PAY_TAB_NAME)) payrollTax,max(decode(hs.PAY_TAB_CODE, '231', hs.PAY_TAB_NAME)) taxableWages 
,max(decode(hs.PAY_TAB_CODE, '242', hs.PAY_TAB_NAME)) paidWages,max(decode(hs.PAY_TAB_CODE, '239', hs.PAY_TAB_NAME)) payable 
,max(decode(hs.PAY_TAB_CODE, '235', hs.T00HS027ID)) payrollTaxId,max(decode(hs.PAY_TAB_CODE, '231', hs.T00HS027ID)) taxableWagesId 
,max(decode(hs.PAY_TAB_CODE, '242', hs.T00HS027ID)) paidWagesId,max(decode(hs.PAY_TAB_CODE, '239', hs.T00HS027ID)) payableId 
,hs.EMPID,hs."MONTH",hs."YEAR",hs.CREATE_DATE createDate,hs.CREATOR,hm2.EMPNO AS CREATORNO,hs.COMPID,HM.EMPNO,HM. NAME AS EmpName
FROM T00HS027 hs , T00HM001 hm  , T00HM001 hm2WHEREhs.EMPID = hm.EMPIDAND hs.T00HM001ID = hm2.EMPIDAND hs."YEAR" = 2023AND hs."MONTH" = 2AND hs.COMPID = '2eec30c2dcb34a1e97c570d34ff900f4'
AND
( hs.PAY_TAB_CODE = '235' OR hs.PAY_TAB_CODE = '242' OR hs.PAY_TAB_CODE = '231' OR hs.PAY_TAB_CODE = '239' )GROUP BY
hs.EMPID,hs."MONTH",hs."YEAR",hs.CREATE_DATE ,hs.CREATOR,hm2.EMPNO ,hs.COMPID,HM.EMPNO,HM.NAME 
ORDER BY hs."YEAR",hs.MONTH
SELECThs.empId,
hs."MONTH",hs."YEAR",hs.CREATE_DATE createDate,hs.CREATOR,hm2.EMPNO AS CREATORNO,hs.COMPID,HM.EMPNO,HM. NAME AS EmpName,MAX (CASEWHEN hs.PAY_TAB_CODE = '235' THENhs.PAY_TAB_NAMEEND) payrollTax,MAX (CASEWHEN hs.PAY_TAB_CODE = '231' THENhs.PAY_TAB_NAMEEND) taxableWages,
MAX (CASEWHEN hs.PAY_TAB_CODE = '242' THENhs.PAY_TAB_NAMEEND) paidWages,
MAX (CASEWHEN hs.PAY_TAB_CODE = '239' THENhs.PAY_TAB_NAMEEND) payable,
MAX (CASEWHEN hs.PAY_TAB_CODE = '235' THENhs.T00HS027IDEND) payrollTaxId,
MAX (CASEWHEN hs.PAY_TAB_CODE = '231' THENhs.T00HS027IDEND) taxableWagesId,MAX (CASEWHEN hs.PAY_TAB_CODE = '242' THENhs.T00HS027IDEND) paidWagesId,MAX (CASEWHEN hs.PAY_TAB_CODE = '239' THENhs.T00HS027IDEND) payableIdFROMT00HS027 hs,T00HM001 hm,T00HM001 hm2WHEREhs.EMPID = hm.EMPIDAND hs.T00HM001ID = hm2.EMPIDAND hs."YEAR" = 2023AND hs."MONTH" = 2AND hs.COMPID = '2eec30c2dcb34a1e97c570d34ff900f4'
GROUP BYhs.empId,hs."YEAR"
,hs."MONTH",hs.CREATE_DATE ,hs.CREATOR,hm2.EMPNO ,
hs.COMPID,HM.EMPNO,HM. NAME 

http://www.ppmy.cn/news/178500.html

相关文章

RTX A2000显卡评测

A2000采用了半高双槽的设计的设计。 全卡采用涡轮风扇加散热鳍片全覆盖的设计。 卡背芯片位置有辅助散热片。输出采用了四个DP1.4接口。 RTX A2000显卡怎么样这些点很重要 http://www.adiannao.cn/dq 显卡可以加载更大的图形,能以更流畅的交互性能给用户带来更好的体…

rx580 8g显卡相当于什么n卡 rx580 8g属于什么级别的

rx580显卡相当于GTX 1060,不过在性能方面比GTX 1060公版要强17%~22%,但落后于GTX 1070显卡22%~28%左右。 rx580怎么样这些点很重要看过你就懂了 http://www.adiannao.cn/dq 具体介绍如下:   1、rx580显卡相当于GTX 1060,不过在性…

LINUX下安装NVIDIA显卡驱动

昨晚费了九牛二虎之力,终于成功的在openSUSE 10.2上安装了nVIDIA显卡驱动,有必要记录一下。 软硬件环境: CPU:AMD Athlon64 X2 5000 AM2(65纳米) 显卡:影驰8500GTE魔影”(显示芯片:GeForce 8500…

电脑为啥不能测试计算机得分,鲁大师性能测试多少分算好电脑,我的电脑处理器...

公告: 为响应国家净网行动,部分内容已经删除,感谢读者理解。 话题:鲁大师性能测试多少分算好电脑,我的电脑处理器性能578显推荐回答:这个分数相当的低了。 现在的入门级家用双核怎么着也要有个1200~1500分 显卡45分很像老显卡比如7300GT、8500GT这样的 内存2G的基本都是25…

独立显卡没有信号输出

前不久在显示器公司工作的哥们送了两块讯景的显卡,用上了独立显卡就是比集成显卡爽,玩极品飞车可以把画面调节得更加细腻,而且不卡,钱花到还是有好处的啊,不过俺是借了哥们的光了。 今晚下班回家开机,发现显…

pg8000

# 背景知识 首先要知道,pg8000是一个客户端, 它会与postgre服务器端的程序进行通信, 发送一些数据给服务器,并接收服务器的返回。 比如发送用户名、密码等用来认证的信息,或者是发送sql语句等等。 接收的是服务器返回…

ubuntu8.10显卡驱动安装(8500gt)

如下是我从网上找到的显卡驱动的安装方法,我按照手动方法使用NVIDIA-Linux-x86-177.80-pkg1.run 安装了我8500gt的显卡,还是很好的,3d效果也出来了,希望能节省大家的时间,安装以后发现菜单栏及最小化/最大化…

设计规则之开闭原则

tip: 需要《设计模式之禅》的书籍,可以联系我 作为程序员一定学习编程之道,一定要对代码的编写有追求,不能实现就完事了。我们应该让自己写的代码更加优雅,即使这会费时费力。 相关规则: 1.6大设计规则-迪米特法则 …