Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> PostgreSQL. Не создаётся функция. 
V
    Опции темы
DarkProg
Дата 17.8.2014, 23:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Законченный романтик
***


Профиль
Группа: Завсегдатай
Сообщений: 1784
Регистрация: 11.3.2009
Где: Земля

Репутация: нет
Всего: 19



Всем привет )
Осваиваю новую для себя СУБД.
Пробую слепить простенькую функцию, но не выходит, то ли у меня уже глаз замылен, то ли я чего-то не понимаю в этом мире.

Вот текст того, что я пытаюсь скормить СУБД, чтобы создать свою функцию(думаю тут и без дополнительных пояснений всё понятно будет)

Код

CREATE OR REPLACE FUNCTION DAYNAME_OF_WEEK
(
   _DATEON date_time
)
RETURNS string20 as
$$
BEGIN
  case extract(weekday from _DATEON)
    when 1 then return 'Понедельник'
    when 2 then return 'Вторник'
    when 3 then return 'Среда'
    when 4 then return 'Четверг'
    when 5 then return 'Пятница'
    when 6 then return 'Суббота'
    when 7 then return 'Воскресенье'
    else return 'Такого дня не существует'
  end;
end;
$$
  LANGUAGE 'plpgsql';


Выдаёт вот такую ошибку 
Код

ERROR:  syntax error at or near "when"
LINE 10:     when 2 then return 'Вторник'


Версия сервера PostgreSQL 9.3


--------------------
"И твоя голова всегда в ответе за то куда сядет твой зад..."

"Я студент - скажите с какого я ВУЗа..."

 smile  smile  smile 
PM MAIL   Вверх
Zloxa
Дата 18.8.2014, 09:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3470
Регистрация: 12.9.2008

Репутация: 3
Всего: 161



Запяточие после "return 'Понедельник'"?


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
DarkProg
  Дата 18.8.2014, 11:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Законченный романтик
***


Профиль
Группа: Завсегдатай
Сообщений: 1784
Регистрация: 11.3.2009
Где: Земля

Репутация: нет
Всего: 19



Не, не угадали )))


Действительно замаялся к вечеру, оказывается нельзя использовать команды внутри case.

Должно быть вот так

Код

CREATE OR REPLACE FUNCTION DAYNAME_OF_WEEK
(
   _DATEON date_time
)
RETURNS string20 as
$$
BEGIN
  return case extract(weekday from _DATEON)
    when 1 then 'Понедельник'
    when 2 then 'Вторник'
    when 3 then 'Среда'
    when 4 then 'Четверг'
    when 5 then 'Пятница'
    when 6 then 'Суббота'
    when 7 then 'Воскресенье'
    else 'Такого дня не существует'
  end;
end;
$$
  LANGUAGE 'plpgsql';


Весьма красиво если честно относительно того, что было раньше, по сути пожно сказать, что однострочная функция )))


--------------------
"И твоя голова всегда в ответе за то куда сядет твой зад..."

"Я студент - скажите с какого я ВУЗа..."

 smile  smile  smile 
PM MAIL   Вверх
Zloxa
Дата 18.8.2014, 11:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3470
Регистрация: 12.9.2008

Репутация: 3
Всего: 161



Цитата(DarkProg @  18.8.2014,  12:23 Найти цитируемый пост)
 оказывается нельзя использовать команды внутри case.

Вроде же можно.
Я так понимаю:
Есть case - statement 39.6.2.4. Simple CASE. То, что вы пытались применить в первом примере. И там нужны запяточия.
Есть case - expression  9.16.1. CASE. То, что вы применили в конце концов. И там запяточия, да - не нужны.

Это сообщение отредактировал(а) Zloxa - 18.8.2014, 11:39


--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
DarkProg
Дата 18.8.2014, 21:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Законченный романтик
***


Профиль
Группа: Завсегдатай
Сообщений: 1784
Регистрация: 11.3.2009
Где: Земля

Репутация: нет
Всего: 19



Да, судя по прикреплённым ссылкам действительно можно ) Только синтаксис я неправильно использовал и выглядело оно как второе, хотя написал как первое ) В общем я понял, что надо быть аккуратнее )))


--------------------
"И твоя голова всегда в ответе за то куда сядет твой зад..."

"Я студент - скажите с какого я ВУЗа..."

 smile  smile  smile 
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PostgreSQL | Следующая тема »


 




[ Время генерации скрипта: 0.1229 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.