여러 테이블을 조인하는 쿼리로 작업할 때 흔히 발생하는 문제 모호한 열 이름 오류. 이는 조인된 테이블 전체에 동일한 열 이름이 존재하여 SSMS(SQL Server Management Studio)가 올바른 테이블 참조를 할당하는 데 어려움을 겪는 경우에 발생합니다.
다음 쿼리를 예로 들어 보겠습니다.
SELECT VendorName, InvoiceID, InvoiceSequence, InvoiceLineItemAmount FROM Vendors JOIN Invoices ON (Vendors.VendorID = Invoices.VendorID) JOIN InvoiceLineItems ON (Invoices.InvoiceID = InvoiceLineItems.InvoiceID) WHERE Invoices.InvoiceID IN (SELECT InvoiceSequence FROM InvoiceLineItems WHERE InvoiceSequence > 1) ORDER BY VendorName, InvoiceID, InvoiceSequence, InvoiceLineItemAmount
이 쿼리에서는 "Vendors", "Invoices" 및 "InvoiceLineItems"라는 세 개의 테이블에서 데이터를 검색하려고 시도합니다. 그러나 실행 시 "InvoiceID" 필드에 대한 모호한 열 이름 오류가 발생합니다.
이 문제를 해결하는 열쇠 이 문제는 모호한 열을 참조할 때 테이블 이름을 명시적으로 지정하는 데 있습니다. 열 이름에 테이블 이름을 접두사로 추가하면 우리가 참조하는 테이블의 열이 무엇인지 명확해집니다.
이 예에서는 "InvoiceID" 열이 "Invoices"와 "InvoiceLineItems" 모두에 존재하므로 테이블의 경우 다음과 같이 쿼리에 원하는 테이블을 지정해야 합니다.
SELECT VendorName, Invoices.InvoiceID, InvoiceSequence, InvoiceLineItemAmount FROM Vendors JOIN Invoices ON (Vendors.VendorID = Invoices.VendorID) JOIN InvoiceLineItems ON (Invoices.InvoiceID = InvoiceLineItems.InvoiceID) WHERE Invoices.InvoiceID IN (SELECT InvoiceSequence FROM InvoiceLineItems WHERE InvoiceSequence > 1) ORDER BY VendorName, Invoices.InvoiceID, InvoiceSequence, InvoiceLineItemAmount
"송장"을 추가합니다. "InvoiceID" 앞에는 "Invoices" 테이블의 "InvoiceID" 열에서 값을 검색하도록 명시적으로 지정하여 모호성을 제거하고 SSMS가 쿼리를 올바르게 실행할 수 있도록 합니다.
SQL에서 모호한 열 이름 오류가 발생하는 경우 항상 테이블 이름을 명시적으로 명시해야 합니다. 해당 열을 참조합니다. 이렇게 하면 SQL Server에 명확한 지침을 제공하고 정확한 쿼리 결과를 보장할 수 있습니다.
위 내용은 SQL 조인에서 모호한 열 이름 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!