Rumah  >  Artikel  >  pangkalan data  >  Bagaimana untuk Mengemas kini Jadual dengan Subquery dalam Klausa SET dalam MySQL?

Bagaimana untuk Mengemas kini Jadual dengan Subquery dalam Klausa SET dalam MySQL?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-10-27 02:41:03227semak imbas

How to Update a Table with a Subquery in the SET Clause in MySQL?

pertanyaan kemas kini mysql menggunakan subquery

Percubaan untuk mengemas kini jadual menggunakan subquery sebagai sebahagian daripada klausa SET telah mengalami ralat, dengan sintaks dibenderakan sebagai tidak betul. Isu khusus boleh dikaitkan dengan klausa WHERE berikutnya dalam pernyataan UPDATE.

Update Competition
Set Competition.NumberOfTeams =
(
SELECT count(*) as NumberOfTeams
FROM PicksPoints
where UserCompetitionID is not NULL
group by CompetitionID
) a
where a.CompetitionID =  Competition.CompetitionID

Masalah timbul kerana penapis WHERE pada pernyataan kemas kini luar dilaksanakan sebelum subquery dalam. Oleh itu, hasil subkueri tidak boleh digunakan untuk menapis jadual yang sedang dikemas kini. Penyelesaian biasa untuk isu ini ialah menggunakan kemas kini berbilang jadual.

Update
  Competition as C
  inner join (
    select CompetitionId, count(*) as NumberOfTeams
    from PicksPoints as p
    where UserCompetitionID is not NULL
    group by CompetitionID
  ) as A on C.CompetitionID = A.CompetitionID
set C.NumberOfTeams = A.NumberOfTeams

Dalam pertanyaan yang disemak ini, kemas kini berbilang jadual digunakan, dengan Persaingan sebagai jadual utama yang akan dikemas kini (disebut sebagai C) . Kami melakukan gabungan dalaman antara Persaingan dan subkueri (disebut sebagai A) yang mengira NumberOfTeams untuk setiap CompetitionId. Klausa WHERE kini digunakan untuk menapis hasil gabungan, memastikan bahawa hanya baris yang sepadan dalam kedua-dua jadual dikemas kini.

[Demo](http://www.sqlfiddle.com/#!2/a74f3/1 ) untuk pertanyaan yang dikemas kini.

Atas ialah kandungan terperinci Bagaimana untuk Mengemas kini Jadual dengan Subquery dalam Klausa SET dalam MySQL?. 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