加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – NHibernate生成带有错误连接的SQL

发布时间:2020-12-15 07:59:52 所属栏目:百科 来源:网络整理
导读:我有一个NHibernate Linq查询,它没有按我的预期工作. 问题似乎来自于在where子句中使用左连接表中的可空int列.这导致联接像内部联接一样运行. var list = this.WorkflowDiaryManager.WorkflowActionRepository.All .Fetch(x = x.CaseView) .Fetch(x = x.Work
我有一个NHibernate Linq查询,它没有按我的预期工作.

问题似乎来自于在where子句中使用左连接表中的可空int列.这导致联接像内部联接一样运行.

var list = this.WorkflowDiaryManager.WorkflowActionRepository.All
    .Fetch(x => x.CaseView)
    .Fetch(x => x.WorkflowActionType)
    .ThenFetchMany(x => x.WorkflowActionPriorityList)
    .Where(x => x.AssignedUser.Id == userId || x.CaseView.MooseUserId == userId)

由此产生的SQL看起来像(从加入开始 – 您不需要查看所有选择)

from Kctc.WorkflowAction workflowac0_ 
left outer join Kctc.WorkflowCaseView workflowca1_ on workflowac0_.CaseId=workflowca1_.CaseId 
left outer join Kctc.WorkflowActionType workflowac2_ on workflowac0_.WorkflowActionTypeId=workflowac2_.WorkflowActionTypeId 
left outer join Kctc.WorkflowActionPriority workflowac3_ on workflowac2_.WorkflowActionTypeId=workflowac3_.WorkflowActionTypeId,Kctc.WorkflowCaseView workflowca4_ 
where workflowac0_.CaseId=workflowca4_.CaseId 
and (workflowac0_.AssignedUser=@p0 or workflowca4_.[MooseUserId]=@p1);
@p0 = 1087 [Type: Int32 (0)],@p1 = 1087 [Type: Int32 (0)]

因此导致问题的部分是上面代码片段的第5行.正如您所看到的,NHibernate正在尝试在WorkflowCaseView View上进行“老派”连接.这会导致查询排除WorkflowAction表中没有CaseId的其他有效操作.

任何人都可以解释为什么NHibernate正在编写这个SQL,以及我如何鼓励它产生更好的查询?

谢谢!

WorkflowActionMap中的重要位

Table("Kctc.WorkflowAction");
        Id(x => x.Id).GeneratedBy.Identity().Column("WorkflowActionId");
        References(x => x.WorkflowActionType).Column("WorkflowActionTypeId").Unique();
        References(x => x.CompletedBy).Column("CompletedBy");
        References(x => x.CaseView).Column("CaseId").Not.Update().Unique();
        References(x => x.AssignedUser).Column("AssignedUser");

WorkflowCaseViewMap的重要部分

Table("Kctc.WorkflowCaseView");
        Id(x => x.Id).Column("CaseId");
        Map(x => x.MooseUserId).Nullable();

看着这个,我想知道我是否应该让HasMany回到另一个方向……

编辑.似乎没有帮助

解决方法

我认为您需要将Where子句更改为:
.Where(x => x.AssignedUser.Id == userId || 
       (x.CaseView != null && x.CaseView.MooseUserId == userId))

使用当前的Where子句,您告诉NHibernate总会有一个CaseView,因为您无条件地访问其属性.根据这些信息,NHibernate优化您的查询,从左外连接到内连接(“老派”连接是)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读