Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Menggunakan Pembolehubah Dengan Betul Dalam Pernyataan SELECT MySQL?

Bagaimanakah Saya Boleh Menggunakan Pembolehubah Dengan Betul Dalam Pernyataan SELECT MySQL?

DDD
DDDasal
2024-12-16 14:13:09972semak imbas

How Can I Correctly Use Variables Within a MySQL SELECT Statement?

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!

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