ホームページ >データベース >mysql チュートリアル >SQL 結合におけるあいまいな列名を解決するにはどうすればよいですか?

SQL 結合におけるあいまいな列名を解決するにはどうすればよいですか?

DDD
DDDオリジナル
2024-12-31 21:07:15709ブラウズ

How Can I Resolve Ambiguous Column Names in SQL Joins?

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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。