Mesej ralat "nama lajur samar-samar" dalam pertanyaan SQL timbul apabila cuba mengakses lajur dengan nama pendua daripada berbilang jadual bercantum. Untuk menyelesaikan kekaburan ini, adalah penting untuk menentukan jadual dari mana lajur itu dipilih.
Dalam pertanyaan yang diberikan, ralat berlaku dengan lajur InvoisID, yang wujud dalam kedua-dua jadual Invois dan InvoiceLineItems. Untuk menyelesaikan masalah ini, ubah suai 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 awalan jadual "Invois" sebelum "ID Invois," pertanyaan secara eksplisit menunjukkan bahawa lajur harus diambil daripada jadual Invois. Ini menyelesaikan kekaburan dan membenarkan SQL Server Management Studio (SSMS) mengambil dan memaparkan lajur VendorID dengan betul.
Ingat untuk menentukan awalan jadual untuk semua lajur samar-samar untuk mengelakkan ralat ini apabila menanyakan data daripada berbilang jadual.
Atas ialah kandungan terperinci Bagaimana untuk Menyelesaikan Ralat 'Nama Lajur Samar-samar' dalam Pertanyaan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!