Друзья, вопрос по поводу переменных в MySQL. Обнаружил два синтаксиса:



SELECT @average := ROUND(AVG(amount)) FROM book;
SET @poetry_id = (SELECT genre_id FROM genre WHERE name_genre = 'Поэзия');

По поводу ":=" и "=" нашел инф-ю в мануале: https://dev.mysql.com/doc/refman/8.0/en/user-variables.html —> они взаимозаменяемые

А вот по поводу разницы между SELECT и SET пытался загуглить что-то на уровне "mysql select vs set for variables" — но ничего не удалось найти, в мануале, вроде, тоже инф-и такой не нашел, поэтому обращаюсь к сообществу с вопросом: есть ли разница между SELECT и SET? Если нет, то почему разится синтаксис? Как по мне, синонимы сбивают с толку...

P.S. если что я новичок, только изучаю все это, фрагменты кода нашел в иных решениях, по ним и вопрос

1 ответов

30 просмотров

Разница между SELECT и SET в контексте переменных заключается в том, что SELECT используется для присвоения значения переменной на основе результата выполнения запроса, а SET используется для явного присвоения значения переменной. В вашем примере, SELECT используется для присвоения значения переменной @average, которое является результатом выполнения функции AVG(). А SET используется для явного присвоения значения переменной @poetry_id, которое является результатом выполнения подзапроса. Выбор между SELECT и SET зависит от того, каким образом вы хотите присвоить значение переменной. Если вы хотите использовать результат выполнения запроса для присвоения значения переменной, то используйте SELECT. Если вы хотите явно присвоить значение переменной, то используйте SET. Синтаксис ":=" и "=" в данном случае действительно взаимозаменяемы, но могут использоваться в зависимости от предпочтений программиста.

Похожие вопросы

Обсуждают сегодня

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта