Como armazenar o resultado da consulta em uma variável usando mysql

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

Quando eu executo essa consulta com a setvariável esse erro é mostrado.

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
fonte

Respostas:

150

Cerque essa seleção com parênteses.

SET @v1 := (SELECT COUNT(*) FROM user_rating);
SELECT @v1;
Sergio Tulentsev
fonte
12
Essa subconsulta deve conter apenas 1 linha e 1 coluna? 1. #1242 - Subquery returns more than 1 row , 2.#1241 - Operand should contain 1 column(s)
Shafizadeh
1
@RajatGupta: onde você está executando isso? E definir "não funciona".
Sergio Tulentsev
3
@Shafizadeh: sim, essa subconsulta deve retornar apenas uma linha e coluna
Sergio Tulentsev
1
@Black: talvez algumas das outras respostas funcionem.
Sergio Tulentsev
2
Parece que o valor de retorno tem que ser um, não uma lista de valores
Victor S
36

Além disso, se você deseja definir múltiplas variáveis ao mesmo tempo por uma consulta, você pode usar a outra sintaxe para definir variáveis que é assim: SELECT @varname:=value.

Um exemplo prático:

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

usa isto

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

testado e funciona bem ...

Aman Maurya
fonte
o que []significa colchetes nesta declaração?
Amin
nada, é apenas um marcador de posição, pule [] e coloque seu valor entre aspas simples
Aman Maurya
2
Select count(*) from table_name into @var1; 
Select @var1;
Kesha Viveki
fonte