Rumah > pangkalan data > tutorial mysql > 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
Lepaskan: 2024-10-27 02:41:03
asal
345 orang telah melayarinya

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
Salin selepas log masuk

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
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan