Microsoft MVP성태의 닷넷 이야기
안녕하세요! EntityFramework Linq 질문 드리겠습니다. [링크 복사], [링크+제목 복사],
조회: 13073
글쓴 사람
옥코드
홈페이지
첨부 파일
 
(연관된 글이 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)
5223김태균9/19/201914545책 소개 링크가 7.1버전판으로 이어집니다. [1]
5222냥냥이9/14/201914865프로그래밍 논리력이 많이 부족합니다 [3]
5219티지레몬9/9/201916892c# PCB 자동화 프로그램(윈도우 폼 위주로 작업) 제작 준비 [3]
5218민성9/9/201914986안녕하세요 WPF에서 xaml 안에 다른 xaml을 넣고 싶습니다. [1]파일 다운로드1
5216WPF9/8/201916031WPF에서 XAML Islands를 사용하여 Win2D를 사용하니 그래픽 품질이 저하됩니다. [2]파일 다운로드1
5215허송세월9/5/201915767중복실행 방지 관련 문의 [2]파일 다운로드1
5214Jang...9/4/201915247[DB 테이블의 데이터 변경에 대한 알림 처리] SQL-Server말고 MySQL은 불가능하겠죠? [1]
5213진우8/31/201914159c# 람다 변수 캡쳐 문의 [2]
5212심성보8/29/201916376Clipboard내 여러개의 이미지를 PictureBox로 불러오는 문제 [2]
5211최휘철8/24/201915359CLR20r3 관련된 윈도우 오류입니다. ㅠㅠ 도와주세요. / 아래글 관련하여 관련 파일 올려 드려요^^ [1]파일 다운로드1
5210최휘철8/23/201920242CLR20r3 관련된 윈도우 오류입니다. ㅠㅠ 도와주세요. [5]
5209세퉁8/21/201915142폰트 파일 속성 값을 가져오는 방법 질문 드립니다. [2]파일 다운로드1
5208홍길동8/19/201916174DebugDiag에서 .Net의 Stack Trace를 Windbg에서는 어떻게 볼 수 있나요? [3]
5207민성8/16/201914110네 소스 전체를 올리도록 하겠습니다. [2]파일 다운로드1
5206민성8/14/201914656전 재현 가능하다고 봤는데 다시올리도록 하겠습니다. [1]
5205miny...8/14/201914712안녕하세요 .WPF ListBox시 체크박스가 있는데 체크박스에서 체크가 되었는지 알수 있는 방법이 있을까요? [1]
5204영민8/8/201918290안녕하세요 디버깅시 콘솔창을 띠어서 볼수가 없나요? [7]
5202민성8/6/201914562WPF에서 <Application.Resources에 xaml에 있는 icon 값을 저장하고 xaml에 불러다 사용하고 싶은데요 [1]
5201김대훈8/3/201914660상속시 생성자에 대해 질문드립니다 [3]
5200농상7/30/201917454foreach로 데이터 변경 [2]
5190오리다람7/20/201914644질문드립니다. [3]
5189진우7/19/201914701C# 스레드풀 코어별 실행 문의 [2]
5188황태관7/19/201913889비주얼베이직 2019 실행 할때 마다.. [3]
5187플하7/19/201917048UWP 관련 궁금한 사항에 대해서 [1]
5186김대훈7/14/201915774박싱과 언박싱에 대해 [2]
5185농상7/13/201914068Nullable에 대해서 [1]
... 16  17  18  19  20  21  22  23  24  25  26  27  [28]  29  30  ...