顾安稳 2023-02-05 16:58 采纳率: 100%
浏览 19
已结题

SQL语句怎么算时间差

将工作满25周年的员工薪水上调50%,工作满30周年的员工薪水上调80%,已知入职时间,怎么算出来几周年?SQL语句

  • 写回答

4条回答 默认 最新

  • 流比 2023-02-05 17:09
    关注

    假设你的入职时间存储在数据库中的字段名为"start_date",你可以使用下面的 SQL 语句来算出工作周年:

    SELECT 
        start_date,
        DATEDIFF(week, start_date, GETDATE()) as weeks_of_service
    FROM 
        employees
    

    接下来,你可以根据员工的周数差来计算薪水调整:

    SELECT 
        start_date,
        DATEDIFF(week, start_date, GETDATE()) as weeks_of_service,
        CASE 
            WHEN DATEDIFF(week, start_date, GETDATE()) >= 25 AND DATEDIFF(week, start_date, GETDATE()) < 30 THEN salary * 1.5
            WHEN DATEDIFF(week, start_date, GETDATE()) >= 30 THEN salary * 2
            ELSE salary
        END AS adjusted_salary
    FROM 
        employees
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 2月13日
  • 已采纳回答 2月5日
  • 创建了问题 2月5日

悬赏问题

  • ¥15 根据会员信息表绘制堆积柱状图
  • ¥100 华为手机私有App后台保活
  • ¥15 sqlserver中加密的密码字段查询问题
  • ¥20 有谁能看看我coe文件到底哪儿有问题吗?
  • ¥20 我的这个coe文件到底哪儿出问题了
  • ¥15 matlab使用自定义函数时一直报错输入参数过多
  • ¥15 设计一个温度闭环控制系统
  • ¥100 rtmpose姿态评估
  • ¥15 通联支付网上收银统一下单接口
  • ¥15 angular有偿编写,