qq_42474629 2022-07-25 17:45 采纳率: 0%
浏览 19

sqlserver怎么查询一张表中同人员的交叉日期

问下各位老哥,我现在有一个表userinfo,里面有每个人多段的在职期间,如下图:

img

我现在想要获取到一个期间重复的人员,比如其中一个人员有两条数据,分别是:
第一条:2022-05-15 到 2022-05-25
第二条:2022-05-20 到 2022-05-30
就需要将他的身份证号获取到。 这样的sql该怎么写呢,求解答

  • 写回答

1条回答 默认 最新

  • 二当家的白帽子 后端领域优质创作者 2022-07-26 15:43
    关注

    没有验证,大概就是自己和自己做连接查询,相同身份证,并且日期区间重叠应该就是你要的数据吧?

    
    select u1.身份证号,u1.id,u2.id
    from userinfo u1
    join userinfo u2 on u1.身份证号=u2.身份证号 and u1.id<>u2.id
    and u1.入职日期 >= u2.入职日期 and u1.入职日期 <= u2.离职日期
    
    评论

报告相同问题?

问题事件

  • 创建了问题 7月25日

悬赏问题

  • ¥15 咨询一下有关于王者荣耀赢藏战绩
  • ¥100 求购一套带接口实现实习自动签到打卡
  • ¥50 MacOS 使用虚拟机安装k8s
  • ¥500 亚马逊 COOKIE我如何才能实现 登录一个亚马逊账户 下发新 COOKIE ..我使用下发新COOKIE 导入ADS 指纹浏览器登录,我把账户密码 修改过后,原来下发新COOKIE 不会失效的方式
  • ¥20 玩游戏gpu和cpu利用率特别低,玩游戏卡顿
  • ¥25 oracle中的正则匹配
  • ¥15 关于#vscode#的问题:把软件卸载不会再出现蓝屏
  • ¥15 vimplus出现的错误
  • ¥15 usb无线网卡转typec口
  • ¥30 怎么使用AVL fire ESE软件自带的优化模式来优化设计Soot和NOx?