Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Помощь / 2 сообщений из 2, страница 1 из 1
27.10.2014, 17:26:10
    #38788470
lolovec
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помощь
Доброго времени суток.У меня возникла проблема при создании хранимой процедуры.
http://savepic.org/6341677.png
есть некая таблица. мне нужно чтобы при в поле время года вносились записи :"зима","лето","осень","весна" в зависимости от месяца рождения человека.
select month(birthday) from table1;
этот запрос выводит месяца. как я понимаю нужно использовать 2 цикла.do while, для того чтобы обрабатывать строку и 4 цикла if.Но я не могу написать их.
Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
delimiter //
create procedure proc()
Begin
declare col int;
declare y int;
declare x int;
declare year1 int;
select count(*) from table3 into x;
set y=0;
Asd: while i<=a DO
set y=y+1;
select MONTH (birthday) from table3 into year1;
if ((year1='0')or(year1='2')) then Update table3 set vremya_goda = 'zima' ;
if ((year1='3')or(year1='5'))then update table3  set vremya_goda='vesna';
if ((year1='6')or(year1='8'))then update table3  set vremya_goda='leto';
if ((year1='9')or(year1='11'))then update table3 set vremya_goda='osenb';
update table3 set performance=year1 where n_ticket=y;
if y<=x then iterate asd;
else leave asd;
end if;
end loop;
select * from table3;
end//


Что-то пытался, но не вышло. Помогите пожалуйста.

Модератор: Тема перенесена из форума "Microsoft SQL Server".
...
Рейтинг: 0 / 0
28.10.2014, 08:52:26
    #38788865
MasterZiv
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Помощь
lolovec,

легче делать это вычисление при каждой выборке данных.
...
Рейтинг: 0 / 0
Форумы / MySQL [игнор отключен] [закрыт для гостей] / Помощь / 2 сообщений из 2, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]