SET @v1 := SELECT COUNT(*) FROM user_rating;
SELECT @v1
Kiedy wykonuję to zapytanie ze set
zmienną, ten błąd jest wyświetlany.
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
Odpowiedzi:
Otocz, który wybierzesz w nawiasach.
SET @v1 := (SELECT COUNT(*) FROM user_rating); SELECT @v1;
źródło
#1242 - Subquery returns more than 1 row
, 2.#1241 - Operand should contain 1 column(s)
Dodatkowo, jeśli chcesz ustawić wiele zmiennych naraz jednym zapytaniu można użyć innej składni dla ustawiania zmiennych, które idzie tak:
SELECT @varname:=value
.Praktyczny przykład:
SELECT @total_count:=COUNT(*), @total_price:=SUM(quantity*price) FROM items ...
źródło
Użyj tego
SELECT weight INTO @x FROM p_status where tcount=['value'] LIMIT 1;
przetestowane i działa dobrze ...
źródło
[]
oznaczają nawiasy w tym stwierdzeniu?Select count(*) from table_name into @var1; Select @var1;
źródło