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

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 VB.NET操作免驱摄像头
  • ¥15 笔记本上移动热点开关状态查询
  • ¥85 类鸟群Boids——仿真鸟群避障的相关问题
  • ¥15 CFEDEM自带算例错误,如何解决?
  • ¥15 有没有会使用flac3d软件的家人
  • ¥20 360摄像头无法解绑使用,请教解绑当前账号绑定问题,
  • ¥15 docker实践项目
  • ¥15 利用pthon计算薄膜结构的光导纳
  • ¥15 海康hlss视频流怎么播放
  • ¥15 Paddleocr:out of memory error on GPU