Microsoft MVP성태의 닷넷 이야기
2개의 DataTable Join 결과 전체 컬럼을 DataTable 로 리턴하기 [링크 복사], [링크+제목 복사]
조회: 11857
글쓴 사람
강준
홈페이지
첨부 파일
 
2 개의 DataTable 이 있습니다.
이를 Linq 를 이용해 Join 하고 조인한 두 테이블 컬럼 전체를 가져오고 싶은데
방법이 있을까요???

A 테이블과 B 테이블의 컬럼은 동적입니다. 기본키만 같고 그외 컬럼은 어떤 컬럼이 들어올지 알수 없구요

결과를 가지고 foreach 문을 이용해 다시 Datatahle 에 넣는 방법 말고
linq 결과를 가지고 바로 DataTable 로 변환이 가능한지 알고 싶습니다.
select 할때 컬럼을 지정하면 CopyToDataTable() 이 가능하긴 한데 컬럼을 알수없어 전체를 가지고 올때
가능한지 알고 싶습니다.

제가 찾은 바로는
1. DataTable 에 foreach 문을 이용해 넣기
   DataTable dtResult = new DataTable();
   dtResult.Columns.Add() //A,B DataTable 의 컬럼 Add...
   var joinResult = from DA in A.AsEnumerable()
                    join DB in B.AsEnumerable()
                    on new {colA = A.Field<string>("PK1"), colB = A.Field<string>("PK2")}
                    equals new {colA = B.Field<string>("PK1"), colB = B.Field<string>("PK2")}
                    select new { JoinRow = DA.ItemArray.Concat(DB.ItemArray) };
   joinResult.ToList().ForEach(c=>dtResult.Rows.Add(c.JoinRow));


2. var joinResult = from DA in A.AsEnumerable()
                    join DB in B.AsEnumerable()
                    on new {colA = A.Field<string>("PK1"), colB = A.Field<string>("PK2")}
                    equals new {colA = B.Field<string>("PK1"), colB = B.Field<string>("PK2")}
                    into allColumns
                    from result in allclumns
                    select rewult
   DataTable dt = joinResult.CopyToDataTable();

   ==> 이렇게 하면 B 테이블 컬럼데이터만 나오네요 ㅜㅠ

3. linq 사용하지 않고 DataRelation 이용






[연관 글]


donaricano-btn



[최초 등록일: ]
[최종 수정일: 2/19/2016


비밀번호

댓글 쓴 사람
 



2016-02-19 05시12분
정성태
2016-02-19 05시23분
[강준] 답변 주신건 컬럼을 알고 있을때입니다. Datatable 에 Join 조건인 Key 만 알고 있고 그외 어떤 컬럼이 있는지 모를때
A 테이블의 전체 B 테이블의 전체를 가지고 오고 싶은거구요^^
A 테이블의 전체와 B 테이블의 전체를 C 라고 받고 싶은거예요
쿼리문으로 하면
Select A.*, B.* From A JOin B ON A.PK1=B.PK1 AND A.OK2=B.PK2
[손님]
2016-02-19 05시24분
[강준] 불가능한거면 어쩔수 없구요^^; 당연히 될줄 알고 접근했는데 잘 안되서 ㅎㅎ;;
[손님]
2016-02-19 06시13분
잘 조합해 보시면 답이 나옵니다. ^^
정성태
2016-02-19 03시56분
Linq는 결국 메서드 호출!
; http://www.sysnet.pe.kr/2/0/10900
정성태

[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5557임기성9/16/2021203웹 사이트(IIS)가 오류로 인하여 빈번하게 죽는 이슈 문의 [1]
5556hjlee9/13/2021113visual studio 설치 없이 csi.exe (C# interactive) tool을 설치할 수 있을까요? [2]
5555이성열9/2/2021110C# 런타임(Reflection)에서 소스코드에 입력한 함수설명(Summary)을 가져올 수 있을까요? [3]
5554농상9/2/2021311enum 원소값이 중복인 경우 출력 [4]
5553shdtkd378/31/2021291제너릭을 new로 할당했는데 null인 경우가 존재하나요? [1]
5552hjshimdm8/30/2021159C# 폼 - 마우스가 다른 버튼 위를 움직일 때도 폼의 페인트핸들러가 호출되는 것이 맞나요? [2]
5551하나다라마8/27/2021190뽀모도로 타이머 개선사항 [1]
5550하영8/27/2021682SqlDataReader 관련 질문입니다. [8]
5549책 감사합니다8/23/2021635C# 9.0 책 오타 [1]
5548Dev8/23/2021644String의 IndexOfAny 함수 질문 [3]
5547민성8/20/2021598WPF Radio 버튼을 GroupName으로 읽어와서 비교하기 [1]
5546DeveloperST8/19/2021691C++ C# API 연동 관련 [1]
5545영귤8/18/2021255C# 14.3장 예제에서 반환 값의 값 복사 부하가 어디서 발생하는 것인가요? [4]
5544이상호8/18/2021161C# Graphics 객체 저장 가능 여부 [2]
5543정형지8/18/2021185c# outofmemoryexception [3]
5542영귤8/11/2021243C#9.0 886쪽 오류 발생 안 해요 [2]
5541서지훈8/11/2021297C# 응용프로그램(Winform)의 비정상 종료(Exit Code) [2]
5540산들마을호랑이8/11/2021291C# 많은 Control(Label 300개) Update 관련 문의 [2]파일 다운로드1
5539초초초촙8/9/2021128c# textbox 입력값이 다름 [1]파일 다운로드1
5538VS8/7/2021143vsmacros 확장자 파일을 사용하는 방법을 알 수 있을까요? [2]
5537민성8/6/2021164안녕하세요 WPF에서 이미 있는창이 있다면 안띠우게 하는 방법 [1]
55358/5/2021281안녕하세요. 초보 웹 개발자입니다. [10]파일 다운로드2
5534하영7/28/2021307clrprofiler 를 사용하여 세션정보 접근 [6]파일 다운로드1
5533함준혁7/20/2021175.net fpspread 관련 질문입니다.. [1]
5532조윤상7/15/2021362바인딩은 성공 했습니다. 그런데 브라우저에서 인증서가 없다고 나옵니다. [2]
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...