Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 11.02.2016
Сообщений: 30

Использование курсоров

20.11.2017, 18:12. Показов 1105. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Разработать курсор для вывода списка имён и фамилий клиентов с образованием равным master

Так выглядит таблица из которой берутся данные
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
TABLE Persons 
 
( id_per INTEGER NOT NULL, 
 
firstname VARCHAR(20) NOT NULL, 
 
secondname VARCHAR(20), 
 
age INTEGER CHECK(age>18), 
 
phone NUMERIC NOT NULL, 
 
educ VARCHAR(30) DEFAULT 'bakalavr', 
 
PRIMARY KEY(id_per));
Вот что я пробовал написать, не работает. Помогите исправить

SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
DECLARE @firstname1 VARCHAR(50),
        @secondname1  VARCHAR(50),
        @message VARCHAR(80)
PRINT 'Список клиентов'
DECLARE klient_cursor CURSOR LOCAL FOR
    SELECT firstname, secondname
    FROM persons
    WHERE educ='master'
    ORDER BY firstname, secondname
 
OPEN klient_cursor
FETCH NEXT FROM klient_cursor INTO @firstname1, @secondname1 
WHILE @@FETCH_STATUS=0
BEGIN
    SELECT @message='Клиент_имя '+@firstname1+
                    ' Клиент_фам '+ @secondname1
    PRINT @message
 
    FETCH NEXT FROM klient_cursor 
      INTO @firstname1, @secondname1 
END
CLOSE klient_cursor
DEALLOCATE klient_cursor
Добавлено через 30 минут
Нужно для PostgreSQL 9.6
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.11.2017, 18:12
Ответы с готовыми решениями:

Создание файлов иконок и курсоров
Всем привет!!! Хочу написать программу для создания курсоров и иконок,только вот не знаю как это сделать,может у кого есть ссылки на эту...

Порядок объявления курсоров и хэндлеров
Написал хранимую процедуру. При её написании MySQL Workbench ничего красным не подчеркивает. При попытке создать таковую хранимую процедуру...

превышено максимальное количество открытых курсоров
Добрый день! Вот с чем я столкнулся - превышено максимальное количество открытых курсоров. Как же быть? Помогите кто может. ...

1
1267 / 980 / 385
Регистрация: 02.09.2012
Сообщений: 3,027
21.11.2017, 16:19
Цитата Сообщение от Ghost48624 Посмотреть сообщение
Вот что я пробовал написать, не работает. Помогите исправить
Конечно не работает, потому что писать не пробовали, а просто сперли из mssql.
Хоть называйте вещи своими именами.

Чтобы исправить, надо:
1. завести анонимый блок или функцию на plpgsql
2. не использовать "собаку" в идентификаторах
3. после декларации переменной ставится точка с запятой
4. После всех деклараций не хватает блока BEGIN...END
5. print нету, есть raise notice, например
6. цикл while просто в loop преобразуем с использованием exit для выхода
7. FETCHить следует в переменную специального типа RECORD
8. raise notice поддерживает переменные, поэтому message не нужно.
9. deallocate тоже можно убрать

Кликните здесь для просмотра всего текста

SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
DO LANGUAGE plpgsql
$$
DECLARE 
  klient_cursor CURSOR FOR SELECT firstname, secondname FROM persons WHERE educ='master' ORDER BY firstname, secondname;
  klient_cursor_row RECORD;
BEGIN
 
raise notice 'Список клиентов';
 
OPEN klient_cursor;
LOOP
  FETCH FROM klient_cursor INTO klient_cursor_row;
EXIT WHEN NOT FOUND;
  raise notice 'Клиент_имя %s Клиент_фам %s', klient_cursor_row.firstname, klient_cursor_row.secondname;
END LOOP;
CLOSE klient_cursor;
 
END
$$;
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.11.2017, 16:19
Помогаю со студенческими работами здесь

Как отключить отображение курсоров в Chart?
Использую код для отображения курсоров на диаграмме по оси X и Y. Скажите, как теперь можно отключить их отображение. private void...

Работа с файлами курсоров. (.cur файлы)
Здравсвуйте. Вот так делаю загрузку курсора в TImage: var hCursor:LongInt; Bitmap:TBitMap; begin Bitmap:= TBitmap.Create; ...

Как считать данные с курсоров SignalExpress
Доброго! Никак не могу считать данные с курсоров в LabVIEW SignalExpress. Речь идет о: Нужно экспортировать данные с...

Работа с данными таблицы без циклом и курсоров
Всем доброго дня. Прошу прощение за вопрос, уверен что он задавался не один раз и было много обсуждений по этому поводу, но тем не менее...

Надо сделать несколько курсоров мыши на экране
Подскажите, возможно ли реализовать такую задачу: Нужно сделать одновременно несколько курсоров мыши на экране. Расположены они к...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru