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!