关于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

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