Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Menyelesaikan Nama Lajur Samar-samar dalam SQL Joins?

Bagaimanakah Saya Boleh Menyelesaikan Nama Lajur Samar-samar dalam SQL Joins?

DDD
DDDasal
2024-12-31 21:07:15709semak imbas

How Can I Resolve Ambiguous Column Names in SQL Joins?

Mengendalikan Nama Lajur Kabur dalam Pertanyaan SQL

Apabila mendapatkan semula data daripada berbilang jadual melalui gabungan, anda mungkin menghadapi mesej ralat yang menunjukkan lajur samar-samar nama. Ini berlaku apabila nama lajur yang sama wujud dalam dua atau lebih jadual yang dicantumkan, menyebabkan jurubahasa pertanyaan tidak pasti tentang jadual mana yang hendak dirujuk.

Sebagai contoh, dalam pertanyaan yang disediakan, kedua-dua InvoiceLineItems dan Invois mengandungi lajur bernama ID Invois. Apabila mendapatkan semula ID Invois dalam pertanyaan, SQL Server menjadi keliru tentang jadual mana untuk mendapatkan semula data.

Untuk menyelesaikan kekaburan ini, anda mesti menentukan nama jadual bagi setiap lajur yang anda rujuk. Dalam kes ini, anda boleh mengemas kini pertanyaan seperti berikut:

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

Dengan menyatakan Invois.InvoiceID, anda secara eksplisit memberitahu SQL Server bahawa anda ingin mendapatkan semula nilai InvoiceID daripada jadual Invois. Ini menghapuskan kekaburan dan membenarkan pertanyaan untuk dilaksanakan dengan betul.

Sebagai alternatif, anda boleh menggunakan alias jadual untuk menetapkan setiap jadual pengecam unik. Sebagai contoh, anda boleh alias Invois sebagai Inv dan InvoiceLineItems sebagai ILI dan mengemas kini pertanyaan dengan sewajarnya:

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

Menggunakan alias jadual menyediakan cara lain untuk menyelesaikan kesamaran nama lajur dan memastikan bahawa pertanyaan mengembalikan hasil yang betul.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menyelesaikan Nama Lajur Samar-samar dalam SQL Joins?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn