简体   繁体   English

复杂查询不适用于实体框架“; WITH”

[英]Complex query is not working with Entity Framework “;WITH”

I am working with multi-level marketing application, with Entity Framework. 我正在使用Entity Framework进行多层营销应用程序。 I have create a stored procedure but somehow the query shown below is not working - why? 我已经创建了一个存储过程,但是以某种方式无法显示下面的查询-为什么?

;WITH OrgTree ([GenealogyTreeID], [MemberRegisterId], [ParentMemberRegisterId], Level) AS
(
    SELECT 
        [GenealogyTreeID], [MemberRegisterId],
        [ParentMemberRegisterId], 0 AS Level 
    FROM 
        GenealogyTree 
    WHERE 
        ParentMemberRegisterId IS NULL --= 'c9f8479f-2bad-4a70-9c0c-e5c9c6bb1e26'

    UNION ALL

    SELECT 
        g.[GenealogyTreeID], g.[MemberRegisterId],
        g.[ParentMemberRegisterId], OrgTree.Level + 1 
    FROM 
        GenealogyTree g
    JOIN 
        OrgTree ON g.ParentMemberRegisterId = OrgTree.MemberRegisterId
)
SELECT DISTINCT
    g.GenealogyTreeID, g.MemberRegisterId,  
    CASE 
       WHEN g.Level = 0 THEN NULL
       ELSE g.ParentMemberRegisterId 
    END AS ParentMemberRegisterId,  
    g.Level, 
    ISNULL((mmr.FirstName + ' ' + mmr.MiddleName + ' ' + mmr.LastName),
    (mr.FirstName + ' ' + mr.MiddleName + ' ' + mr.LastName)) as ParentFullName,
    (mr.FirstName + ' ' + mr.MiddleName + ' ' + mr.LastName) as SelFullName,
    mr.photo
FROM
    OrgTree g 
INNER JOIN 
    MemberRegister mr on mr.MemberRegisterId = g.MemberRegisterId
INNER JOIN 
    MemberRegister mmr on mmr.MemberRegisterId = g.ParentMemberRegisterId 
WHERE
    mr.FirstName LIKE '%'+ @SearchValue +'%' 
    OR mr.MiddleName LIKE '%'+ @SearchValue +'%' 
    OR mr.LastName LIKE '%'+ @SearchValue +'%'
    OR mmr.FirstName LIKE '%'+ @SearchValue +'%' 
    OR mmr.MiddleName LIKE '%'+ @SearchValue +'%' 
    OR mmr.LastName LIKE '%'+ @SearchValue +'%' 
ORDER BY
    ParentMemberRegisterId
    OFFSET @PageSize * (@PageNo - 1) ROWS
    FETCH NEXT @PageSize ROWS ONLY
    OPTION (RECOMPILE);

You should remove first ; 您应该首先删除;

WITH OrgTree
  ...
;

Otherwise ORM would get first statement as empty one and ignore the second. 否则,ORM将使第一个语句为空,而忽略第二个。

;WITH pattern is used because ; ;WITH模式是因为; is not mandatory in general in T-SQL but a few statements require it like CTE/MERGE. 通常在T-SQL中不是强制性的,但是有一些语句要求这样做,例如CTE / MERGE。 This is why some developers start WITH with ; 这就是为什么一些开发商开始WITH;

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM