powered by simpleCommunicator - 2.0.51     © 2025 Programmizd 02
Форумы / Firebird, InterBase [игнор отключен] [закрыт для гостей] / оператор if в процедуре...Parsing Error
10 сообщений из 10, страница 1 из 1
оператор if в процедуре...Parsing Error
    #39672113
SlavikArhan
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Доброго дня! Дописываю хранимую процедуру...У процедуры куча выходных параметров, один из которых мне важен, это тип сервиса...До внесения моих правок, процедура абсолютно рабочая...выводит заданные выходные параметры...один из этих параметров мне интересен, это servicetypename...IBExpert все что то ругается, может подчеркивает vpisano=''; Parsing Error...может по синтаксису что то не то?...суть в чем, в зависимости от типа сервиса, в выходную переменную записывается определенное значение...выходную переменную определил, тип varchar

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
vpisano='';
      if (:servicetypename='Цифровое ТВ') then begin
      into :vpisano='text1';
      end

      if (:servicetypename='СКТВ') then  begin
      into :vpisano='text2';

      if (:servicetypename='ТАКП') then  begin
      into :vpisano='text3';
      end

      if (:servicetypename='Интернет') then  begin
      into :vpisano='text4';
      end

      if (:servicetypename='Интернет') then  begin
      into :vpisano='text5';
      end
...
Рейтинг: 0 / 0
оператор if в процедуре...Parsing Error
    #39672119
AltHasp
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
SlavikArhan,

1) уберите into везде где хотите присвоить значение переменной;
2) для однострочных if не нужен begin...end;
3) лучше будет если видеть весь техт ХП, а то гадать приходится.

Удачи !
...
Рейтинг: 0 / 0
оператор if в процедуре...Parsing Error
    #39672120
Фотография Симонов Денис
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
SlavikArhan,

ну и где ты такой синтаксис нашёл? Читай https://www.firebirdsql.org/file/documentation/reference_manuals/firebird-language-reference-30-rus.pdf
...
Рейтинг: 0 / 0
оператор if в процедуре...Parsing Error
    #39672122
AltHasp
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
SlavikArhan,

как то так наверное:

Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
begin
vpisano='';
      if (:servicetypename='Цифровое ТВ') then  vpisano='text1';
      if (:servicetypename='СКТВ')             then  vpisano='text2';
      if (:servicetypename='ТАКП')             then  vpisano='text3';
      if (:servicetypename='Интернет')       then  vpisano='text4';
      if (:servicetypename='Интернет')       then  vpisano='text5';

end



Ксати четвёртый и пятый пункт дублируется, так не должно быть.
...
Рейтинг: 0 / 0
оператор if в процедуре...Parsing Error
    #39672125
AltHasp
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
SlavikArhan,

вместо строкового параметра :servicetypename обычно используют её индекс (цифры).

И получше будет, если хотя бы так:

Код: plsql
1.
2.
3.
4.
5.
6.
begin

select first 1 field1 from table1 where serv_name= :servicetypename into :vpisano;

  suspend;
end
...
Рейтинг: 0 / 0
оператор if в процедуре...Parsing Error
    #39672138
Фотография kdv
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
AltHaspвместо строкового параметра :servicetypename обычно используют её индекс (цифры).
что-что?
AltHaspИ получше будет, если хотя бы так:
так будет хуже, и в контексте вопроса вообще бред. Где вы там таблицу увидели?
...
Рейтинг: 0 / 0
оператор if в процедуре...Parsing Error
    #39672140
IBExpert
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Я буду краток:

Код: plsql
1.
vpisano = :servicetypename;



И больше ничего не нужно :)
...
Рейтинг: 0 / 0
оператор if в процедуре...Parsing Error
    #39672330
fraks
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Еще вариант
Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
execute block
returns (
  vpisano varchar(20)
)
as
declare variable serticetypename varchar(20);
begin
  serticetypename = 'СКТВ';
  --
  vpisano = case serticetypename
    when 'Цифровое ТВ'   then 'text1'
    when 'СКТВ'          then 'text2'
    when 'ТАКП'          then 'text3'
    else ''
  end;
  --
  suspend;
end
...
Рейтинг: 0 / 0
оператор if в процедуре...Parsing Error
    #39672469
SlavikArhan
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Господа, спасибо большое! Прикрутил код у процедуре...
...
Рейтинг: 0 / 0
оператор if в процедуре...Parsing Error
    #39672899
SlavikArhan
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
fraks, благодарю, все таки Вашу реализацию взял за основу в ХП
...
Рейтинг: 0 / 0
10 сообщений из 10, страница 1 из 1
Форумы / Firebird, InterBase [игнор отключен] [закрыт для гостей] / оператор if в процедуре...Parsing Error
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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