Come memorizzare il risultato della query in una variabile utilizzando mysql


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

Quando eseguo questa query con la setvariabile viene visualizzato questo errore.

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

Risposte:


148

Racchiudi quella selezione tra parentesi.

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

12
Quella sottoquery dovrebbe contenere solo 1 riga e 1 colonna? 1. #1242 - Subquery returns more than 1 row , 2.#1241 - Operand should contain 1 column(s)
Shafizadeh

1
@RajatGupta: dove lo stai eseguendo? E definire "non funzionante".
Sergio Tulentsev

2
@Shafizadeh: sì, quella sottoquery dovrebbe restituire solo una riga e una colonna
Sergio Tulentsev,

Non funziona per me, provato su phpmyadmin mysql. Viene visualizzato un errore che dice "È stata trovata una nuova istruzione, ma non c'è delimitatore tra questa e la precedente" (tradotto dal tedesco).
Nero

1
Sembra che il valore restituito debba essere uno, non un elenco di valori
Victor S

35

Inoltre, se si desidera impostare più variabili in una sola volta da una query, è possibile utilizzare l'altra sintassi per impostare variabili che va in questo modo: SELECT @varname:=value.

Un esempio pratico:

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

8

Usa questo

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

testato e funziona bene ...


cosa significa parentesi []in questa affermazione?
amin

niente è solo un segnaposto salta [] e metti il ​​tuo valore tra virgolette singole
Aman Maurya

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.