Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/http/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
旧作业和新作业列SQL_Sql_Oracle_Pivot - Fatal编程技术网

旧作业和新作业列SQL

旧作业和新作业列SQL,sql,oracle,pivot,Sql,Oracle,Pivot,是否可以显示3个新列-旧作业、新作业、起始日期 下面我有一个sql示例 select emp_no, emp_name, job_title, valid_from, valid_to from tableA 我想展示一些专栏- Emp无Emp名称,旧工作,新工作,起始日期 “旧职务”和“新职务”是职务名称中的值,“起始日期”从开始生效 短暂性脑缺血发作 Yasir尝试lag: select * from ( select

是否可以显示3个新列-旧作业、新作业、起始日期

下面我有一个sql示例

select
    emp_no,
    emp_name, 
    job_title, 
    valid_from,
    valid_to
    
from 
   tableA
我想展示一些专栏-

Emp无Emp名称,旧工作,新工作,起始日期

“旧职务”和“新职务”是职务名称中的值,“起始日期”从开始生效

短暂性脑缺血发作

Yasir

尝试
lag

select *
from (
  select
    emp_no,
    emp_name,
    lag(job_title) over (partition by emp_no order by valid_from) as old_job,
    job_title as new_job,
    valid_from
  from tableA
)
where old_job is not null

看起来像是
lead/lag
而不是
pivot
请提供示例数据和所需的输出附加图像作为参考图像,请作为旁白阅读,我不太喜欢“神奇日期”。ie:valid_to=31/12/9999。如果'valid_to'日期尚未确定(无论出于何种原因),则将其保留为空。谢谢。我会试试看