> 백엔드 개발 > C++ > LINQ를 사용하여 C#의 DataTable에 대해 내부 조인을 수행하는 방법은 무엇입니까?

LINQ를 사용하여 C#의 DataTable에 대해 내부 조인을 수행하는 방법은 무엇입니까?

DDD
풀어 주다: 2025-01-12 17:32:43
원래의
857명이 탐색했습니다.

How to Perform an Inner Join on DataTables in C# using LINQ?

C#에서 LINQ를 사용하여 DataTable에 내부 조인

내부 조인은 공통 열을 기반으로 두 개 이상의 테이블에서 데이터를 검색하는 관계형 데이터베이스 작업입니다. C#에서는 LINQ를 포함한 다양한 기술을 사용하여 DataTable에 대한 내부 조인을 수행할 수 있습니다.

LINQ 방법:

LINQ가 옵션인 경우 다음 코드 조각은 두 DataTable(T1 및 T2)에서 내부 조인을 수행하는 방법을 보여줍니다.

<code class="language-csharp">DataTable dt1 = new DataTable();
dt1.Columns.Add("CustID", typeof(int));
dt1.Columns.Add("ColX", typeof(int));
dt1.Columns.Add("ColY", typeof(int));

DataTable dt2 = new DataTable();
dt2.Columns.Add("CustID", typeof(int));
dt2.Columns.Add("ColZ", typeof(int));

// 添加一些示例数据
for (int i = 1; i <= 5; i++)
{
    dt1.Rows.Add(i, 10 + i, 20 + i);
    dt2.Rows.Add(i, 30 + i);
}

// 使用LINQ执行内连接
var results = from table1 in dt1.AsEnumerable()
              join table2 in dt2.AsEnumerable() on table1.Field<int>("CustID") equals table2.Field<int>("CustID")
              select new
              {
                  CustID = table1.Field<int>("CustID"),
                  ColX = table1.Field<int>("ColX"),
                  ColY = table1.Field<int>("ColY"),
                  ColZ = table2.Field<int>("ColZ")
              };

// 输出结果
foreach (var item in results)
{
    Console.WriteLine(String.Format("ID = {0}, ColX = {1}, ColY = {2}, ColZ = {3}", item.CustID, item.ColX, item.ColY, item.ColZ));
}</code>
로그인 후 복사

이 LINQ 쿼리는 두 테이블의 on 열이 동일해야 함을 지정하는 CustID 절을 사용하여 내부 조인을 수행합니다. 결과는 CustID, ColX, ColYColZ 열을 포함하는 익명 유형으로 반환됩니다.

출력:

이 코드는 다음 결과를 출력합니다.

ID = 1, ColX = 11, ColY = 21, ColZ = 31 ID = 2, ColX = 12, ColY = 22, ColZ = 32 ID = 3, ColX = 13, ColY = 23, ColZ = 33 ID = 4, ColX = 14, ColY = 24, ColZ = 34 ID = 5, ColX = 15, ColY = 25, ColZ = 35

위 내용은 LINQ를 사용하여 C#의 DataTable에 대해 내부 조인을 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿