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!