今天在使用sqlsugar查询数据库信息的时候出现了以下这个问题:
异常显示C.Inspect_Id这个字段有问题,于是我先去检查了实体类里面关于这个字段的绑定,确定这个字段是没有问题的,于是我尝试找sqlsugar生成后的SQL语句:
于是我在QueryBuilder里面找到了sqlsugar拼接后的sql,发现在进行左连接的时候,sqlsugar是按照表格顺序生成sql的,而我在写JoinType.Left的时候未按照顺序写,导致A,B两张表进行left join的时候,我写的是A,C两张表的条件,left join与on的条件错位,所以出现了上述问题,于是我将顺序调换成如下,问题就解决了:
所以在使用sqlsugar进行多张表关联查询的时候,一定要注意表的顺序,按照db.Queryable<A,B,C>这里添加的顺序依次进行绑定,sqlsugar在生成sql语句的时候也是按照这个顺序进行的。