salary
(
FID int, //记录ID
FName Varchar(10),//员工姓名
Fdate Datetime,//日期
FSalary float //余额
)
表内记录了公司所有员工的薪水发放记录(注:薪水可能是按周发放,也可能是按月发放 按日发放),数据可能跨年。
(1).现要得出名为张三的员工在本年所得薪水总和,请写出sql语句
(2).现要求计算出每个员工的按年,月统计的薪水报表,请写出SQL语句
(3).现要求计算出月薪介于500—800的员工姓名(要求名字不重复,含500和800)

解决方案 »

  1.   


    --(1)
    select max(FSalary)-min(FSalary) 薪水总和 
    from salary 
    where FName='张三' and trunc(Fdate)=trunc(sysdate)
    group by trunc(Fdate);--(2)
    --按年:
    select FName 员工姓名,to_char(trunc(Fdate),'yyyy')||'年' 年份,max(FSalary)-min(FSalary) 薪水
    from salary 
    group by FName,trunc(Fdate);
    --按月:
    select FName 员工姓名,to_char(trunc(Fdate,'mm'),'yyyy-mm')||'月' 月份,max(FSalary)-min(FSalary) 薪水
    from salary 
    group by FName,trunc(Fdate,'mm');--(3)
    select distinct 员工姓名 from (
           select FName 员工姓名,to_char(trunc(Fdate,'mm'),'yyyy-mm')||'月' 月份,max(FSalary)-min(FSalary) 薪水
            from salary 
           group by FName,trunc(Fdate,'mm')
    )
    where 薪水 between 500 and 800;
      

  2.   

    1.select sum(FSalary) from  salary where fname = ‘张三' and to_char(fdate,'yyyy')=to_char(sysdate,'yyyy')2.select fid,fname,sum(fsalary) from salary group by fid,fname,to_char(fdate,'yyyy-mm')3.select distinct fname from salary where fsalary >= 500 and fsalary <= 800 
      

  3.   

    表内记录了公司所有员工的薪水发放记录(注:薪水可能是按周发放,也可能是按月发放 按日发放),数据可能跨年。
    (1).现要得出名为张三的员工在本年所得薪水总和,请写出sql语句
    select sum(FSalary) from salary where FName='张三' and Fdate between to_date('20100101','yyyymmdd') and to_date('20101231','yyyymmdd');(2).现要求计算出每个员工的按年,月统计的薪水报表,请写出SQL语句
    select FName,to_char(Fdate,'yyyymm'),sum(FSalary)
    from salary
    group by FName,to_char(Fdate,'yyyymm')(3).现要求计算出月薪介于500—800的员工姓名(要求名字不重复,含500和800)select distinct FName
    from(
    select FName,to_char(Fdate,'yyyymm'),sum(FSalary) as mFSalary
    from salary
    group by FName,to_char(Fdate,'yyyymm')
    )
    where mFSalary between 500 and 800
      

  4.   

    peipengfei (peipengfei)
      '截至2010-10-07 08:11:25  用户结帖率0.00%  当您的问题得到解答后请及时结贴.
    http://topic.csdn.net/u/20090501/15/7548d251-aec2-4975-a9bf-ca09a5551ba5.html
    http://topic.csdn.net/u/20100428/09/BC9E0908-F250-42A6-8765-B50A82FE186A.html
    http://topic.csdn.net/u/20100626/09/f35a4763-4b59-49c3-8061-d48fdbc29561.html8、如何给分和结贴?
    http://community.csdn.net/Help/HelpCenter.htm#结帖