[英]how to get value of next column below previous column in DB2 Sql
我有一个如下表,我想获取 IN 列下方的 OUT 列值并添加一条新记录。
create table Temp (
[name] varchar(10),
[In] varchar(10),
[Out] varchar(10),
[HRs] varchar(10),
);
insert into Temp values('bob','login','logout','8');
insert into Temp values('alice','login','logout','9');
insert into Temp values('peter','login',null,'0');
表output
姓名 | 在 | 出去 | 人力资源 |
---|---|---|---|
鲍勃 | 登录 | 登出 | 8 |
爱丽丝 | 登录 | 登出 | 9 |
彼得 | 登录 | NULL | 0 |
预计 Output
姓名 | 在 | 人力资源 |
---|---|---|
鲍勃 | 登录 | 8 |
鲍勃 | 登出 | 8 |
爱丽丝 | 登录 | 9 |
爱丽丝 | 登出 | 9 |
彼得 | 登录 | 0 |
彼得 | NULL | 0 |
我需要在 Temp 表上实现上述 output 将 IN 和 OUT 列合并到 IN 列中,如何在 DB2 sql 中实现这一点
一种方法使用联合:
SELECT NAME, "IN", HRs
FROM
(
SELECT NAME, "IN", HRs, 1 AS pos FROM Temp
UNION ALL
SELECT NAME, "OUT", HRs, 2 FROM Temp
) t
ORDER BY NAME, pos;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.