SqlSugar查询达梦数据库遇到的异常情况

  使用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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值