≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > SQL Server

SQL Server SQL语句练习实例之一找出最近的两次晋升日期与工资额

人气:412 时间:2019-11-28

这篇文章主要为大家详细介绍了SQL Server SQL语句练习实例之一找出最近的两次晋升日期与工资额,具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!

代码如下:

 
--程序员们在编写一个雇员报表,他们需要得到每个雇员当前及历史工资状态的信息, 
--以便生成报表。报表需要显示每个人的晋升日期和工资数目。 
--如果将每条工资信息都放在结果集的一行中,并让宿主程序去格式化它。 
--应用程序的程序员都是一帮懒人,他们需要在每个雇员的一行上得到当前 
--和历史工资信息。这样就可以写一个非常简单的循环语句。 
---示例: 
create table salaries 
( name nvarchar(50) not null, 
sal_date date not null, 
salary money not null, 
) 
go 
ALTER TABLE [dbo].salaries ADD CONSTRAINT [PK_salaries] PRIMARY KEY CLUSTERED 
( 
name ,sal_date asc 
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, 
SORT_IN_TEMPDB = OFF, IGNORE_DUP_KEY = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON, 
ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] 
GO 

----插入数据 
insert into salaries 
select 'TOM','2010-1-20',2000 
union 
select 'TOM','2010-6-20',2300 
union 
select 'TOM','2010-12-20',3000 
union 
select 'TOM','2011-6-20',4000 
union 
select 'Dick','2011-6-20',2000 
union 
select 'Harry','2010-6-20',2000 
union 
select 'Harry','2011-6-20',2000 

go 

----方法一、使用left join 连接进行查询(sql 2000及以上版本) 
select b.name,b.maxdate,y.salary,b.maxdate2,z.salary 
from(select a.name,a.maxdate,MAX(x.sal_date) as maxdate2 
from(select w.name,MAX(w.sal_date) as maxdate 
from salaries as w 
group by w.name) as a 
left outer join salaries as x on a.name=x.name and a.maxdate>x.sal_date 
group by a.name,a.maxdate) as b 
left outer join salaries as y 
on b.name=y.name and b.maxdate=y.sal_date 
left outer join salaries as z 
on b.name=z.name and b.maxdate2=z.sal_date 

go 
----方法二、这个方法是对每个雇员中的行进行编号,然后取出两个雇用日期最近的日期, 

---(sql 2005以上版本) 
select s1.name, 
MAX(case when rn=1 then sal_date else null end) as curr_date, 
MAX(case when rn=1 then salary else null end) as curr_salary, 
MAX(case when rn=2 then sal_date else null end) as prev_date, 
MAX(case when rn=2 then salary else null end) as curr_salary 
from (select name,sal_date,salary, RANK() over(partition by name order by sal_date desc) rn 
from salaries 
) s1 where rn<3 group by s1.name 


go 
---方法三、在sql server 2005之后版本可以使用这种方法 ,使用CTE的方式来实现 
with cte(name,sal_date,sal_amt,rn) 
as 
( 
select name,sal_date,salary,ROW_NUMBER() over(PARTITION by name order by sal_date desc) as rn from salaries 
) 
select o.name,o.sal_date AS curr_date,o.sal_amt as curr_amt,i.sal_date as prev_date ,i.sal_amt as prev_amt from cte as o 
left outer join cte as i on o.name=i.name and i.rn=2 where o.rn=1 

go 

----方法四、使用视图,将问题分为两种情况 

---1.只有一次工资变动的雇员 

---2.有两次或多次工资变动的雇员 
create view v_salaries 
as 
select a.name,a.sal_date,MAX(a.salary) as salary from salaries as a ,salaries as b 
where a.sal_date<=b.sal_date and a.name=b.name group by a.name,a.sal_date 
having COUNT(*)<=2 
go 
select a.name,a.sal_date, a.salary,b.sal_date,b.salary from v_salaries a 
,v_salaries b 
where a.name=b.name and a.sal_date>b.sal_date 
union all 
select name,max(sal_date),max(salary),cast(null as date),cast(null as decimal(8,2)) 
from v_salaries 
group by name 
having count(*)=1 

go 
drop table salaries 
go 
drop view v_salaries 

本文来自:http://www.q1010.com/179/8002-0.html

注:关于SQL Server SQL语句练习实例之一找出最近的两次晋升日期与工资额的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:SQL SERVER

您可能感兴趣的文章

  • SQL Server利用sys.sysprocesses检查SqlServer的阻塞和死锁
  • SQLServer 全文检索(full-text)语法
  • SQL Server 2000 升级到 SQLServer 2008 性能之需要注意的地方之一
  • SQL Server 一次性压缩Sqlserver2005中所有库日志的存储过程
  • SQLServer 跨库查询实现方法
  • SQL Server 数据库主键的生成方式小结(sqlserver,mysql)
  • SQL Server使用cmd命令行窗口操作SqlServer的方法
  • SQLServer 2005 实现数据库同步备份 过程-结果-分析
  • SQL Server CREATE FUNCTION sqlserver用户定义函数
  • sqlserver 查询数据库大小的方法
上一篇:SQL Server Table中XML列的操作代码
下一篇:SQL Server 很有意思的SQL多行数据拼接
热门文章
  • SQL Server SQL获取第一条记录的方法
  • SQL Server出现System.OutOfMemoryException异常的解决方法
  • SQL Server的 update from 语句的简单示例
  • SQL Server 数据库备份方法菜鸟教程
  • SQL Server 多表关联时在where语句中慎用trim()方法
  • SQL Server数据类型及长度限制详细说明
  • mybaits非配置原因,导致SqlSession was not registered for synchronization异常解析
  • SQL Server 收缩后对数据库的使用有影响吗?
  • SQL Server 格式导致的Excel导入sql出现异常的解决方法
  • SQL Server 连接服务器出现错误 7391的解决方法
  • 最新文章
    • SQL Server存储过程基本语法的简单示例
    • sql查询时增加自动编号和分页的简单示例
    • sql轻松应付百万数据的高效数据分页存储过程的简单示例
    • sql获取一条数据中所有字段的名称和值的实现方法
    • sql分割函数的简单示例
    • SQL Server异常捕获的简单示例
    • SQL SERVER回滚恢复误操作数据的实现方法
    • SQL Server函数或存储过程中抛出异常的实现方法
    • SQL Server创建数据库的完整代码
    • SQL Server创建数据库的命令用法示例

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。