Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Menyelesaikan Ralat 'Nama Lajur Samar-samar' dalam Pertanyaan SQL?

Bagaimana untuk Menyelesaikan Ralat 'Nama Lajur Samar-samar' dalam Pertanyaan SQL?

Patricia Arquette
Patricia Arquetteasal
2025-01-03 05:36:44607semak imbas

How to Resolve

Nama Lajur Samar-samar dalam Pertanyaan SQL: Menyelesaikan Isu ID Invois

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!

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