skyblue丶 2021-12-21 19:42 采纳率: 100%
浏览 17
已结题

关于sqlserver 的问题:为什么这段子查询SQL 只能查到最先插入到子表hgt里面的记录

 select 
hf.Context,hf.id,hf.TruckID,ht.id 
FROM HGTruck(NOLOCK) AS ht   
 LEFT JOIN (
            SELECT TOP 1 hgt.TruckID,hgt.Context AS Context                            
             FROM HGTruckFollow hgt
            WHERE hgt.Context='司机身份信息已经确认'
            ORDER by hgt.id DESC
            ) AS hf ON hf.TruckID=ht.ID
        WHERE  ht.TruckOrder IN ('121601','121501')

请教一下,为什么这段SQL 只能查到 最先插入到子表hgt里面的记录。

比如121601这条记录在hgt表中已经有一条司机身份信息已经确认记录(这个时候能显示出来),然后我再操作121501插入一条司机身份信息已经确认记录,那么我就只能关联上121501这条的记录,121601这条的子表记录却显示为null。

img

img

实际上子表中是有对应ID的数据的。121501对应95804,121601对应95805

img

  • 写回答

1条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2021-12-21 20:47
    关注

    你的主表和子表是用 hf.TruckID=ht.ID 这个条件进行join的,所以你不光要看子表的id是否存在,最主要的是看主表的TruckID是否存在,因为你这是个left join,是以左边为准去匹配右边的

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 12月30日
  • 已采纳回答 12月22日
  • 创建了问题 12月21日

悬赏问题

  • ¥30 STM32 INMP441无法读取数据
  • ¥100 求汇川机器人IRCB300控制器和示教器同版本升级固件文件升级包
  • ¥15 用visualstudio2022创建vue项目后无法启动
  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境