Переменные (Transact-SQL)
Локальная переменная Transact-SQL представляет собой объект, содержащий одно значение определенного типа. Переменные обычно используются в пакетах и скриптах:
- в качестве счетчика цикла;
- для хранения значения, которое необходимо проверить инструкцией управления потоком;
- для хранения значения, возвращенного функцией или хранимой процедурой.
- Имена некоторых системных функций Transact-SQL начинаются с двух символов @ (@@). Хотя в предыдущих версиях сервера SQL Server @@функции называются глобальными переменными, @@функции не являются переменными и используются иначе. @@functions являются системными функциями, а их синтаксис использует правила для функций.
- В представлении нельзя использовать переменные.
- Откат транзакции не влияет на изменения переменных.
Следующий скрипт создает небольшую тестовую таблицу из 26 строк. Переменная используется в скрипте в качестве:
- счетчика цикла для управления количеством вставляемых строк;
- значения, вставляемого в столбец целочисленного типа;
- аргумента функции, формирующей строку, которая вставляется в столбец символьного типа:
-- Create the table. CREATE TABLE TestTable (cola INT, colb CHAR(3)); GO SET NOCOUNT ON; GO -- Declare the variable to be used. DECLARE @MyCounter INT; -- Initialize the variable. SET @MyCounter = 0; -- Test the variable to see if the loop is finished. WHILE (@MyCounter < 26) BEGIN; -- Insert a row into the table. INSERT INTO TestTable VALUES -- Use the variable to provide the integer value -- for cola. Also use it to generate a unique letter -- for each row. Use the ASCII function to get the -- integer value of 'a'. Add @MyCounter. Use CHAR to -- convert the sum back to the character @MyCounter -- characters after 'a'. (@MyCounter, CHAR( ( @MyCounter + ASCII('a') ) ) ); -- Increment the variable to count this iteration -- of the loop. SET @MyCounter = @MyCounter + 1; END; GO SET NOCOUNT OFF; GO -- View the data. SELECT cola, colb FROM TestTable; GO DROP TABLE TestTable; GO
Объявление переменных в языке Transact-SQL
Инструкция DECLARE инициализирует переменную Transact-SQL следующим образом:
- Назначение имени. Имя должно иметь один @ в качестве первого символа.
- Назначение длины и типа данных, определяемого системой или пользователем. Для числовых переменных задаются также точность и масштаб. Для переменных типа XML может быть дополнительно задана коллекция схем.
- Присваивает созданной переменной значение NULL.
Например, следующая инструкция DECLARE создает локальную переменную @mycounter типа int.
DECLARE @MyCounter INT;
Инструкция DECLARE позволяет объявить несколько переменных одинакового или разного типов через запятую.
Например, следующая инструкция DECLARE создает три локальные переменные с именем @LastName, @FirstName и @StateProvince, присваивая каждой из них значение NULL:
DECLARE @LastName NVARCHAR(30), @FirstName NVARCHAR(20), @StateProvince NCHAR(2);
Областью видимости переменной называют диапазон инструкций Transact-SQL, которые могут к ней обращаться. Областью видимости переменной являются все инструкции между ее объявлением и концом пакета или хранимой процедуры, где она объявлена. Например, следующий скрипт содержит синтаксическую ошибку, поскольку переменная объявлена в одном пакете, а используется в другом:
USE AdventureWorks2022; GO DECLARE @MyVariable INT; SET @MyVariable = 1; -- Terminate the batch by using the GO keyword. GO -- @MyVariable has gone out of scope and no longer exists. -- This SELECT statement generates a syntax error because it is -- no longer legal to reference @MyVariable. SELECT BusinessEntityID, NationalIDNumber, JobTitle FROM HumanResources.Employee WHERE BusinessEntityID = @MyVariable;
Переменные имеют локальную область видимости и доступны только внутри пакета или процедуры, где они объявлены. В следующем примере вложенная область видимости, созданная для выполнения процедуры sp_executesql, не имеет доступа к переменной, объявленной в более высокой области видимости, и возвращает ошибку:
DECLARE @MyVariable INT; SET @MyVariable = 1; EXECUTE sp_executesql N'SELECT @MyVariable'; -- this produces an error
Присвоение значения переменной в языке Transact-SQL
При объявлении переменной присваивается значение NULL. Чтобы изменить значение переменной, применяется инструкция SET. Этот способ присвоения значений переменным является предпочтительным. Кроме того, переменной можно присвоить значение, указав ее в списке выбора инструкции SELECT.
Чтобы присвоить значение переменной при помощи инструкции SET, необходимо указать ее имя и присваиваемое значение. Этот способ присвоения значений переменным является предпочтительным. Например, следующий пакет объявляет две переменные, присваивает им значения и использует их в предложении WHERE инструкции SELECT :
USE AdventureWorks2022; GO -- Declare two variables. DECLARE @FirstNameVariable NVARCHAR(50), @PostalCodeVariable NVARCHAR(15); -- Set their values. SET @FirstNameVariable = N'Amy'; SET @PostalCodeVariable = N'BA5 3HX'; -- Use them in the WHERE clause of a SELECT statement. SELECT LastName, FirstName, JobTitle, City, StateProvinceName, CountryRegionName FROM HumanResources.vEmployee WHERE FirstName = @FirstNameVariable OR PostalCode = @PostalCodeVariable; GO
Переменной можно присвоить значение, указав ее в списке выбора. Если список выбора ссылается на переменную, то ей должно быть присвоено скалярное значение, или инструкция SELECT должна возвращать только одну строку. Например:
USE AdventureWorks2022; GO DECLARE @EmpIDVariable INT; SELECT @EmpIDVariable = MAX(EmployeeID) FROM HumanResources.Employee; GO
Когда при выполнении инструкции SELECT переменной присваивается несколько значений, сервер SQL Server не гарантирует порядок вычисления выражений. Обратите внимание, что этот эффект проявляется, только если инструкция присваивает значение переменной.
Если инструкция SELECT возвращает более одной строки и переменная ссылается на нескалярное выражение, ей присваивается значение, которое возвращается для выражения в последней строке результирующего набора. Например, в следующем пакете переменной @EmpIDVariable присваивается значение идентификатора BusinessEntityID последней возвращенной строки, равное 1:
USE AdventureWorks2022; GO DECLARE @EmpIDVariable INT; SELECT @EmpIDVariable = BusinessEntityID FROM HumanResources.Employee ORDER BY BusinessEntityID DESC; SELECT @EmpIDVariable; GO
Скрипты Simple-Scada
Иногда требуется передавать текущие значения переменных из скада-системы в сторонние приложения. Обычно для этого используется встроенный UA-сервер, который можно включить в проекте Simple-Scada, а затем подключиться к нему любым UA-клиентом и получать значения переменных. Но некоторые приложения не могут работать как UA-клиент и такой способ не подойдет. В данной статье рассмотрим обмен данными через СУБД MySQL. Cкада-система будет сохранять текущие значения переменных в отдельную таблицу БД, а стороннее приложение будет читать эти значения. Сначала нужно создать в БД отдельную таблицу для хранения значений. Запускаем MySQL Workbench, находим БД в которую наш проект сохраняет архивные данные, кликаем ПКМ строку "Tables" и в раскрывшемся меню выбираем "Create Table":

Назовем таблицу "current_values", добавим в нее два столбца:
• id - тип данных INT, включаем флажки PK (Primary Key), NN (Not Null), UN (Unsigned);
• value - тип данных DOUBLE, включаем флажок NN (Not Null);
и нажмем кнопку "Apply":

Откроется окно с SQL-кодом, в нем также нажимаем кнопку "Apply", а затем "Finish". Теперь таблица "current_values" создана. Затем перейдем в редактор скриптов и создадим новый скрипт с типом события "Изменились переменные". Добавим в список скрипта все переменные, значения которых нужно передавать в БД и нажмем кнопку "Создать":

var
aQuery: string ;
begin
aQuery :=
'INSERT INTO `current_values` (`id`, `value`) VALUES (' +
IntToStr(Variable.ID) + ',' +
FloatToStr(Variable.AsFloat, 8 ) +
') ON DUPLICATE KEY UPDATE `value`=' + FloatToStr(Variable.AsFloat, 8 );
RunSQL(aQuery);
end .
Во время работы проекта в таблицу "current_values" будут записываться текущие значения выбранных переменных. Значение в колонке "id" будет соответствовать ID-переменной (ID любой переменной можно посмотреть в редакторе переменных(колонка ID)). При необходимости, через меню "Проект -> Настройки -> База данных -> Другие действия -> Создать таблицу переменных" можно создать в БД таблицу переменных, которая будет содержать список всех переменных проекта. Теперь стороннее приложение может подключиться к БД и считывать значения нужных ему переменных. Пример запроса на выборку:
SELECT `value` FROM `demo_base`.`current_values` WHERE (`id` = 27);
Данный запрос считает из таблицы "current_values" текущее значение переменной с >
Вывод переменных из БД
Доброго времени суток.
У меня возникли вопросы по поводу вывода переменных из базы данных.
Допустим я в базе данных создал таблицу под названием my_table.
Далее эта таблица содержит id и name.
Как сделать вывод переменной name в модуле, где > SQL запросом я добавил модуль с определённым названием.
Далее я делал по инструкции на сайте, в которой рассказывается как создать модуль.
Но у меня ничего не вышло, не выводятся переменные.
ByFly
- Минск
- Испытатели
- Сообщений: 164
#2 15 июля 2013 в 22:12
Лучше всего если прикрепите исходники.
Димитриус
- Мурманск
- Испытатели
- На орбите
- Сообщений: 1225
#3 15 июля 2013 в 22:21
Лучше всего если прикрепите исходники.
Димитриус
ByFly
- Минск
- Испытатели
- Сообщений: 164
Сегодня в 04:35
Реклама
#4 15 июля 2013 в 23:12
$sql — это не массив.
Нормальный хостинг, сервера быстрые - пользуюсь сам.

lokanaft
- Модераторы
- Сообщений: 1422
#5 15 июля 2013 в 23:23
Вытащить из БД переменную?
но если честно не совсем понятно что Вам надо )
Если из БД вернется больше 1 строки - то в переменную to запишется только ПОСЛЕДНЕЕ значение
Если вы уверены что из бд вернется только 1 строка - то да, мой первый вариант сработает
Но если там булет больше 1 строки то:
printf("" .$row['email5'] . "");
заменить на
$to[$i++] = $row['email5'];
тогда ПОСЛЕ цикла - to - уже не переменная, а массив переменных
Ответ написан более трёх лет назад
Комментировать
Нравится Комментировать
Программирование, Серверное администрирование
$sql_select = 'SELECT * FROM ordersait'; $result = mysql_query($sql_select); $row = mysql_fetch_array($result); foreach($row as $to)
Думаю суть ясна, разобраться дальше не составит труда
Ответ написан более трёх лет назад
Комментировать
Нравится Комментировать
Ваш ответ на вопрос
Войдите, чтобы написать ответ

- PHP
- +3 ещё
Как установить nextcloud на NGINX Unit?
- 1 подписчик
- только что
- 1 просмотр