Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / EXECUTE format и ilike / 4 сообщений из 4, страница 1 из 1
24.07.2015, 16:24
    #39015618
BlindG
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
EXECUTE format и ilike
Добрый день

Подскажите пож. что я делаю не так.
Пытаюсь сделать запрос:

Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
  
create table test (name VARCHAR(255));

insert into test(name) 
values('alex'), ('oleg'),('sasha');


DO LANGUAGE plpgsql $$

DECLARE
 template_name varchar(1);
 fresult VARCHAR(100);
BEGIN
template_name := 'A';

execute format('select name from test where name  ILIKE ''%'' || $4 || ''%''')
using template_name
into fresult;

RAISE NOTICE 'name %', fresult;
END;
$$;
 


Получаю:
ОШИБКА: нераспознанный спецификатор преобразования " ' "
CONTEXT: функция PL/pgSQL inline_code_block, строка 8, оператор оператор EXECUTE

Заранее спасибо, за ваши ответы!
...
Рейтинг: 0 / 0
24.07.2015, 16:52
    #39015648
p2.
p2.
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
EXECUTE format и ilike
BlindGОШИБКА: нераспознанный спецификатор преобразования " ' "
не можешь перевести текст ошибки?
...
Рейтинг: 0 / 0
24.07.2015, 16:54
    #39015654
BlindG
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
EXECUTE format и ilike
p2., не могу понять в каком месте ошибка, и почему
...
Рейтинг: 0 / 0
24.07.2015, 17:20
    #39015685
Павел Лузанов
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
EXECUTE format и ilike
Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
  
create table test (name VARCHAR(255));

insert into test(name) 
values('alex'), ('oleg'),('sasha');


DO LANGUAGE plpgsql $$
DECLARE
 template_name varchar(1);
 fresult VARCHAR(100);
BEGIN
   template_name := 'A';

   execute 'select name from test where name  ILIKE ''%'' || $1 || ''%'''
   using template_name
   into fresult;

   RAISE NOTICE 'name %', fresult;
END;
$$;
...
Рейтинг: 0 / 0
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / EXECUTE format и ilike / 4 сообщений из 4, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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