SQL クエリでのあいまいな列名の処理
結合を通じて複数のテーブルからデータを取得するときに、あいまいな列を示すエラー メッセージが表示される場合があります。名前。これは、結合された 2 つ以上のテーブルに同じ列名が存在する場合に発生し、どのテーブルを参照すればよいかクエリ インタプリタに不確かなままになります。
たとえば、提供されたクエリでは、InvoiceLineItems と Invoices の両方に、という名前の列が含まれています。請求書ID。クエリで InvoiceID を取得する場合、SQL Server はどのテーブルからデータを取得するか混乱します。
この曖昧さを解決するには、参照する各列にテーブル名を指定する必要があります。この場合、次のようにクエリを更新できます。
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
Invoices.InvoiceID を指定することにより、Invoices テーブルから InvoiceID 値を取得することを SQL Server に明示的に指示します。これにより、あいまいさがなくなり、クエリを正しく実行できるようになります。
あるいは、テーブル エイリアスを使用して各テーブルに一意の識別子を割り当てることもできます。たとえば、Invoices を Inv として、InvoiceLineItems を ILI としてエイリアス化し、それに応じてクエリを更新できます。
SELECT VendorName, Inv.InvoiceID, InvoiceSequence, InvoiceLineItemAmount FROM Vendors AS V JOIN Invoices AS Inv ON (V.VendorID = Inv.VendorID) JOIN InvoiceLineItems AS ILI ON (Inv.InvoiceID = ILI.InvoiceID) WHERE Inv.InvoiceID IN (SELECT InvoiceSequence FROM ILI WHERE InvoiceSequence > 1) ORDER BY VendorName, Inv.InvoiceID, InvoiceSequence, InvoiceLineItemAmount
テーブル エイリアスを使用すると、列名の曖昧さを解決し、クエリが正しい結果を返す別の方法が提供されます。
以上がSQL 結合におけるあいまいな列名を解決するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。