Microsoft MVP성태의 닷넷 이야기
안녕하세요! EntityFramework Linq 질문 드리겠습니다. [링크 복사], [링크+제목 복사],
조회: 15087
글쓴 사람
옥코드
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

EntityFramework를 사용하면서, 기존에 선임이 작업했던 스트링형태의 쿼리문을 전부 EF Linq로 바꾸고 있는데요, 몇가지 복잡한 쿼리문에 대한 문제점이 발생했습니다.

sb.Append("SELECT a.*, c.Flag, c.RelatedTxID ");
sb.Append(" FROM t_BlockChainInfo a ");
sb.Append(" INNER JOIN t_Member b ");
sb.Append(" ON(a.FromID = b.ID ");
sb.Append(" OR a.ToID = b.ID) ");
sb.Append(" LEFT OUTER JOIN t_Transaction c ");
sb.Append(" ON a.TransactionHash = c.txID ");
sb.Append("WHERE b.ProcessID = @ProcessID ");
sb.Append(" AND b.HardDriveID = @HardDriveID ");
sb.Append(" AND b.ID = @ID ");
sb.Append(" AND a.FromID <> a.ToID ");
sb.Append(" AND (a.RegDate BETWEEN @StartDate AND @EndDate) ");

위와 같이 3개의 테이블이 존재하며, Inner Join과 Left Outer join을 통해 해당 data를 얻어오는 작업입니다.

제가 시도했던 방식은 일반 Linq는
var q = from a in t_BlockChainInfo
        join b in t_Member s on a.FromId equals b.Id
 
EF linq 는 ,

var q = _context.t_BlockChainInfo
        .Join(_context.t_Mebers, a=>a.FromId, b=>b.Id)
와 같은 형태로, 위 스트링 형태의 쿼리문처럼 _

ON a.FromID = b.ID OR a.ToID = b.ID <==== OR 부분을 구현하기가 난해하네요;

어떤식으로 EF Linq를 짜야할까요.,.


[연관 글]






[최초 등록일: ]
[최종 수정일: 9/29/2021]


비밀번호

댓글 작성자
 



2021-09-30 09시55분
정성태
2021-09-30 01시53분
[옥코드] 감사합니다 도움이 되었습니다^^
[guest]
2021-09-30 02시26분
그런데, 가만 보니까 INNER JOIN에 OR 조건을 한 것이 사실 CROSS JOIN과 다를 바가 없습니다. 따라서, 다음과 같은 식으로 Linq 쿼리를 작성해도 결과는 동일하게 나올 것입니다.

var q = from a in t_BlockCahinInfo
        from b in t_Member
        where a.FromId == b.Id || a.ToID = b.ID
        ...[생략]...
정성태
2021-09-30 11시55분
다음의 글에 정리했으니 참고하세요.

Entity Framework의 Join 사용 시 다중 칼럼에 대한 OR 조건 쿼리
; https://www.sysnet.pe.kr/2/0/12840
정성태

... 16  [17]  18  19  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5549책 감사...8/23/202118757C# 9.0 책 오타 [1]
5548Dev8/23/202115039String의 IndexOfAny 함수 질문 [3]
5547민성8/20/202113431WPF Radio 버튼을 GroupName으로 읽어와서 비교하기 [1]
5546Deve...8/19/202114462C++ C# API 연동 관련 [1]
5545영귤8/18/202114081C# 14.3장 예제에서 반환 값의 값 복사 부하가 어디서 발생하는 것인가요? [4]
5544이상호8/18/202114590C# Graphics 객체 저장 가능 여부 [2]
5543정형지8/18/202113601c# outofmemoryexception [3]
5542영귤8/11/202118309C#9.0 886쪽 오류 발생 안 해요 [2]
5541서지훈8/11/202118688C# 응용프로그램(Winform)의 비정상 종료(Exit Code) [2]
5540산들마을...8/11/202114676C# 많은 Control(Label 300개) Update 관련 문의 [2]파일 다운로드1
5539초초초촙8/9/202112743c# textbox 입력값이 다름 [1]파일 다운로드1
5538VS8/7/202113246vsmacros 확장자 파일을 사용하는 방법을 알 수 있을까요? [2]
5537민성8/6/202113558안녕하세요 WPF에서 이미 있는창이 있다면 안띠우게 하는 방법 [1]
55358/5/202115385안녕하세요. 초보 웹 개발자입니다. [10]파일 다운로드2
5534하영7/28/202113445clrprofiler 를 사용하여 세션정보 접근 [6]파일 다운로드1
5533함준혁7/20/202112903.net fpspread 관련 질문입니다.. [1]
5532조윤상7/15/202115493바인딩은 성공 했습니다. 그런데 브라우저에서 인증서가 없다고 나옵니다. [2]
5530ocm7/14/202114511pthread_create [7]파일 다운로드1
5529ksc7/13/202113471Source Generator 관련 질문이 있습니다. [1]
5528초심으로7/9/202113747MDI 에서 USB 연결해제 알림이 안되는 문제 질문 드려봅니다. [7]파일 다운로드1
5527wuny7/7/202113908제어관련 고민을하다가 소캣방식 선택 [2]
5526이성열 donator7/7/202116277wpf x64로 만든 메인 프로그램에서 dll로 된 UserControl 속성이 디자인타임에 잘 안보이는 문제 [10]파일 다운로드2
5525Wuny7/7/202116969제가 만든 배포파일은 window에서 막는걸까요? [2]파일 다운로드1
5524하이스컬7/2/202115732특정 이벤트에서 다른 이벤트 호출 관련 문의 [3]
5523민우7/1/202123113도커 사용시 윈도우 이미지 생성도 가능한가요? [2]
5522질문6/28/202115917WPF에서 splash screen이 나타나는 위치를 변경할 수 있나요? [3]
... 16  [17]  18  19  20  21  22  23  24  25  26  27  28  29  30  ...