使用SqlSugar连接达梦数据库,联查两张表的数据遇到的奇怪问题:同一套代码,在一个环境中可以正常查询并返回数据,但在另一环境中运行则查不到数据。在个人电脑上测试时也能正确运行,搞不清楚是怎么回事,特此记录测试过程。
在达梦数据库中创建两张表,CLASS表记录班级数据,STUDENT记录班级学生数据,下面截图是两张表中的测试数据。 代码功能是查找所有有学生的班级信息(本文仅是示例,实际表数据比较复杂,只能单向查),查询逻辑比较简单,条件中的(a.INDEX < 4)仅是为了示意其它条件。
var results = db.Queryable<CLASS, STUDENT>((a, b) => new JoinQueryInfos(JoinType.Left, a.ID == b.CLASSID)).Where((a, b) => (a.INDEX < 4) && !string.IsNullOrEmpty(b.ID)).Select((a, b) => new QueryResult{ClassName = a.NAME,StudentName = b.NAME}).ToList();
上面的代码在测试环境1运行正常,但是到了测试环境2中却查不出来数据,两个环境中的数据库版本、数据库表都相同,只是数据不同。
上述查询代码生成的Sql语句如下,表面上看不出来什么问题,将其在达梦管理工具中逐个排除查询条件,最终发现是NOT( “B”.“ID” IS NULL OR “B”.“ID”=‘’)这个条件出的问题,也就是!string.IsNullOrEmpty(b.ID)代码转换的Sql语句,具体而言是其中的OR “B”.“ID”=‘’,如果仅是NOT( “B”.“ID” IS NULL)也能正常返回数据,加上上面的返回就是空值。
SELECT \"A\".\"NAME\" AS \"CLASSNAME\" , \"B\".\"NAME\" AS \"STUDENTNAME\"
FROM \"CLASS\" \"A\" Left JOIN \"STUDENT\" \"B\" ON ( \"A\".\"ID\" = \"B\".\"CLASSID\" )
WHERE (( \"A\".\"INDEX\" < 4 ) AND NOT( \"B\".\"ID\" IS NULL OR \"B\".\"ID\"=''))
最终也没有找到原因,只能将查询代码修改为下面的形式:
var results = db.Queryable<CLASS, STUDENT>((a, b) => new JoinQueryInfos(JoinType.Left, a.ID == b.CLASSID)).Where((a, b) => (a.INDEX < 4) && b.ID.StartsWith("STUDENT")).Select((a, b) => new QueryResult{ClassName = a.NAME,StudentName = b.NAME}).ToList();
参考文献:
[1]https://www.donet5.com/home/Doc?typeId=1180