Microsoft MVP성태의 닷넷 이야기
안녕하세요! EntityFramework Linq 질문 드리겠습니다. [링크 복사], [링크+제목 복사],
조회: 6409
글쓴 사람
옥코드
홈페이지
첨부 파일
 
(연관된 글이 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
정성태

... 61  62  63  64  65  66  67  68  69  70  [71]  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
754단테3/19/200811138실행파일의 아이콘을 프로그램 적으로 변경할 수 있을까요? [1]
753신동열3/12/200811571비스타의 권한 상승 관련 질문 있습니다. [2]
751김재영3/6/200811228스레드와 비스레드간의 대기상태 순서에 대해 질문이 있습니다. [2]파일 다운로드1
752정성태3/7/200810740    답변글 [답변]: 스레드와 비스레드 간의 대기 상태 순서에 대해 질문이 있습니다. [1]
750김용현3/3/200810089스마트 클라이언트로 파일 다운로드시 파일의 크기가 0인 경우가 발생합니다. [2]
749임영한2/28/2008251852003서버에서 msxml3.dll 오류 "80070005" 문제입니다. [2]
748류재상2/27/200814747Remoting , Tcp Channel 사용시.. 외부에서 접근 보안문제... [3]
747한귀순2/20/200813166WinForm - DataGridView 소계 등 [3]
746박상영2/20/200811042리모팅 관련해서 [3]파일 다운로드1
745조승현2/20/200811896Response.Charset ANSI로 설정..하는부분이 어려워서요.. [1]
744오야2/5/200810353멤버십, 웹파트등의 생성테이블과 업무테이블간의 관계를 어떻게.. [2]
743김기룡1/29/200812431동일 이미지 판단 방법 관련 [2]파일 다운로드1
740경혜원1/28/200813897C#에서 이런게 가능 할런지요?
742정성태1/29/200811904    답변글 [답변]: C#에서 이런게 가능 할런지요? [1]
738임경훈1/25/200812775웹서비스에서 오라클DB에 연결할 때
741임경훈1/28/200812354    답변글 [답변]: 웹서비스에서 오라클DB에 연결할 때 [1]
737단테1/25/200813650안녕하세요 정성태님. C Run-time Library의 배포에 대해서 질문있습니다. [3]
736김현기1/24/200811573XML 접두어 포함한 XmlElement 작성법? [1]
735정명원1/9/200811419ActiveX 사용시 ... [2]
734제영한12/17/200711344웹서비스에서 사용자 정의 예외 사용하기 [2]
732김기룡12/3/200714203WebRequest 요청시 일본어 인코딩 관련 문의파일 다운로드1
733김기룡12/3/200710728    답변글 일어가 깨졌네요..테스트 문자 추가합니다.^^;;파일 다운로드1
739adnim1/27/200811769    답변글 [답변]: WebRequest 요청시 일본어 인코딩 관련 문의 [1]
731우기11/27/20079305[질문] clickonce 배포시 .net framework 2.0, 3.0 설치 시간 줄일 수 있는 묘수없을까요?? [1]
730김재영11/10/20079913스레드에 사용되는 함수에 값을 같이 넘기는 방법이 있습니까?? [2]파일 다운로드1
727제영한10/24/20079222시스템 설계에 대한 문의드립니다.
... 61  62  63  64  65  66  67  68  69  70  [71]  72  73  74  75  ...