Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Использование параметров




 

Без параметров практически невозможно влиять на состояние процедур и функций во время вызова.

 

 

Как видно из данного примера, через параметр par хранимой процедуре proc1 передается числовое значение 123456, которое она присваивает пользовательской переменной @x.

 

Атрибут in сообщает СУБД MySQL, что при помощи параметра par пользователи предают данные внутрь функции. То есть если хранимая процедура будет изменена в соответствии с примером, приведенным ниже, новое значение параметра par, которое присваивается внутри функции, не будет доступно после вызова процедуры.

 

 

Замечание! Имена параметров при объявлении и вызове хранимой процедуры и при вызове необязательно должны совпадать. Внутри хранимой процедуры все локальные переменные используются без символа @, в то время как для глобальных пользовательских переменных символ @ перед именем обязателен.

 

Хранимая процедура proc1 принимает единственный in -параметр par, при помощи оператора set значение параметра изменяется внутри функции. Однако, как видно из приведенного выше примера, после выполнения хранимой процедуры значение пользовательской переменной @y, переданной функции в качестве параметра, не изменяется. Если требуется, чтобы значение переменной подвергалось изменению, необходимо объявить параметр процедуры с модификатором out.

 

 

Как видно из приведенного выше примера, при использовании модификатора out любые изменения параметра внутри процедуры отражаются на параметре. Передача в качестве значения пользовательской переменной позволяет использовать результат процедуры для дальнейших вычислений. Однако передать значение внутрь функции при помощи out -параметра уже не получится.

 

Для того чтобы через параметр можно было передать значение внутрь процедуры и получить значение, которое попадает в параметр в результате вычислений внутри процедуры, его следует объявить с атрибутом inout.

 

 

Теперь через параметр par можно как передавать значения внутрь процедуры, так и извлекать значения, которые получает параметр внутри процедуры. Тем не менее, рекомендуется использовать только in - и out -параметры, не прибегая к комбинированным inout -параметрам, т.к. это приводит к нечитабельному и непоследовательному коду.

 

 




Поделиться с друзьями:


Дата добавления: 2015-05-09; Просмотров: 405; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.011 сек.