Cara menyimpan Hasil Kueri dalam variabel menggunakan mysql

92
SET @v1 := SELECT COUNT(*) FROM user_rating;
SELECT @v1

Ketika saya menjalankan kueri ini dengan setvariabel, kesalahan ini ditampilkan.

Error Code : 1064
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use
near 'SELECT count(*) FROM user_rating' at line 1

Execution Time : 00:00:00:000
Transfer Time  : 00:00:00:000
Total Time     : 00:00:00:000

(1 row(s) returned)
Execution Time : 00:00:00:343
Transfer Time  : 00:00:00:000
Total Time     : 00:00:00:343
Query Master
sumber

Jawaban:

149

Kelilingi pilih dengan tanda kurung.

SET @v1 := (SELECT COUNT(*) FROM user_rating);
SELECT @v1;
Sergio Tulentsev
sumber
12
Haruskah sub query tersebut hanya berisi 1 baris dan 1 kolom? 1. #1242 - Subquery returns more than 1 row , 2.#1241 - Operand should contain 1 column(s)
Shafizadeh
1
@ RajatGupta: di mana kamu menjalankannya? Dan tentukan "tidak berfungsi".
Sergio Tulentsev
3
@Shafizadeh: ya, subkueri itu harus mengembalikan hanya satu baris dan kolom
Sergio Tulentsev
1
@ Hitam: mungkin, beberapa jawaban lain akan berhasil.
Sergio Tulentsev
2
Tampaknya nilai kembali harus satu, bukan daftar nilai
Victor S
35

Selain itu, jika Anda ingin mengatur beberapa variabel sekaligus dengan satu permintaan, Anda dapat menggunakan sintaks lainnya untuk menetapkan variabel yang berjalan seperti ini: SELECT @varname:=value.

Contoh praktis:

SELECT @total_count:=COUNT(*), @total_price:=SUM(quantity*price) FROM items ...
Yirkha
sumber
8

Gunakan ini

 SELECT weight INTO @x FROM p_status where tcount=['value'] LIMIT 1;

diuji dan berfungsi dengan baik ...

Aman Maurya
sumber
apa arti tanda kurung []dalam pernyataan ini?
amin
tidak ada itu hanya lewati placeholder [] dan masukkan nilai Anda dalam tanda kutip tunggal
Aman Maurya
2
Select count(*) from table_name into @var1; 
Select @var1;
Kesha Viveki
sumber