Microsoft MVP성태의 닷넷 이야기
안녕하세요! EntityFramework Linq 질문 드리겠습니다. [링크 복사], [링크+제목 복사]
조회: 914
글쓴 사람
옥코드
홈페이지
첨부 파일
 
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분
[옥코드] 감사합니다 도움이 되었습니다^^
[손님]
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
정성태

1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5645김인태4/6/2022244윈도우즈 서버의 AD 계정 생성 조건이 있을까요? [1]
5644ㅇㅇ4/6/2022360c# 프로그램을 이용하여 리눅스상에 파일 생성이 가능한가요? [1]
5643유필재4/5/2022332TCP클라이언트 연결 및 통신관련하여 문의드려요 [1]
5642차가워4/4/2022350UdpClient 패킷 수신 문의 [4]
5641장성욱4/4/2022355코어 할당 및 cpu 부하테스트 질문 [7]
5640icookie4/4/2022240웹가든에서 메모리 동적 업데이트 방법 [1]
5639차가워4/4/2022226c++ 서버 c# 클라이언트 호환 문의 [1]
5638초급4/3/2022231c# sql server 연동 [1]
5637따봉이4/1/2022273Winform Form Load 후 자동 캡쳐관련 [1]파일 다운로드1
5636김철순3/31/2022351WPF에서 Richtext의 View 문의 [5]
5635손님3/30/2022378안정적인 pinning이 가능하네요. [3]파일 다운로드1
5633꿀주세요3/30/2022479선생님 마우스 클릭이벤트 질문이 있습니다. [4]
5632김현수3/30/2022321Remote Desktop으로 접속시 WPF UI 가 다시 그려지는 이벤트를 막을 수 없을까요? [3]
5631김기헌3/24/2022366WPF 컨트롤의 그래픽 처리관련 질문드립니다 [2]파일 다운로드1
5630장성욱3/24/2022323로깅관련 질문입니다. [2]
5629감사합니다.3/23/2022347함수에서 예외가 발생하면 try ~ catch처리기를 찾을 때 까지 상위 함수로 계속 올라가나요? [2]
5628홍길동3/23/2022319질문드립니다. [2]파일 다운로드1
5626연준혁3/21/2022395안녕하세요. [3]
5625jaewon3/18/2022549c# 8.0 도서를 구입한 사람입니다. [1]
5624초보자3/17/2022393람다 캡처 관련 문의 [2]
5623한예지3/15/2022469인터프리터 원리가 궁금합니다. [4]
5622김민아3/8/2022639const와 readonly의 명확한 차이가 이게 맞나요? [2]
5621장성욱3/8/2022443c# 로그 관련 질문 [1]
5620김민아3/7/2022441안녕하세요 비관리 객체를 반환하는 메소드 호출 시 궁금한 점이 있어서 질문드립니다 [2]
5619팡팡이3/3/2022417RSA 문의드립니다. [3]
5618김기헌3/2/2022448안녕하세요 생성자 옆에 this 키워드를 붙여 생성자를 여러 개 호출 시 질문드립니다 [2]
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...