Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Menggunakan Pembolehubah Dengan Betul Dalam Pernyataan SELECT MySQL?
Menggunakan Pembolehubah dalam Penyata SELECT
Apabila bekerja dengan MySQL, anda mungkin menghadapi senario di mana anda ingin menentukan dan menggunakan pembolehubah dalam SELECT yang sama kenyataan. Walau bagaimanapun, adalah penting untuk mengetahui batasan yang terlibat.
Tugasan Pembolehubah dan Kebolehbacaan
Seperti dalam dokumentasi MySQL, secara amnya tidak disyorkan untuk memberikan nilai kepada pembolehubah pengguna dan membacanya dalam pernyataan yang sama. Susunan penilaian untuk ungkapan yang melibatkan pembolehubah pengguna tidak ditentukan dan mungkin berbeza-beza berdasarkan elemen pernyataan.
Ini bermakna pertanyaan berikut mungkin tidak berfungsi seperti yang diharapkan:
SELECT @z:=SUM(item), 2*@z FROM TableA;
Dalam kes ini , anda mungkin akan mendapat NULL untuk lajur kedua.
Mengapa Perbezaan dengan Prosedur?
Anda mungkin tertanya-tanya mengapa pertanyaan berikut, yang menggunakan prosedur tersimpan dan bukannya pembolehubah pengguna, berfungsi seperti yang diharapkan:
SELECT @z:=someProcedure(item), 2*@z FROM TableA;
Sebab untuk ini adalah yang disimpan prosedur dinilai secara berbeza daripada pembolehubah pengguna. Urutan penilaian untuk prosedur tersimpan ditakrifkan dan konsisten.
Menggunakan Subkueri
Untuk mencapai kefungsian yang diingini, anda boleh menggunakan subkueri:
select @z, @z*2 from (SELECT @z:=sum(item) FROM TableA ) t;
Pendekatan ini menggunakan subkueri untuk memulakan pembolehubah pengguna (@z) dan kemudian merujuknya dalam utama pertanyaan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggunakan Pembolehubah Dengan Betul Dalam Pernyataan SELECT MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!