Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/75: Рейтинг темы: голосов - 75, средняя оценка - 4.72
1 / 1 / 0
Регистрация: 11.10.2015
Сообщений: 46

Хранимые процедуры-превышен уровень вложенности

31.07.2016, 14:00. Показов 14669. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Помогите, пожалуйста, разобраться со вложенностью процедур.
В базе данных есть таблица студентов и групп, студент связан со своей группой по полю Id_Group.
Пытаюсь создать хранимую процедуру, которая показывает, сколько студентов в каждой группе:

T-SQL
1
2
3
4
5
6
7
8
9
10
USE library
GO
CREATE PROCEDURE CountStud
AS
SELECT Groups.Name, COUNT(*)
FROM Groups, Students
WHERE students.Id_Group = Groups.Id
GROUP BY Groups.Name
 
EXECUTE CountStud
Почему в результате выполнения этих строк появляется сообщение "Выполнение команд успешно завершено" а не выводится на экран таблица - результат select'а?
И самое главное, почему в дальнейшем, когда пытаешься выполнить только строчку
T-SQL
1
EXECUTE CountStud
select начинает выполняться многократно (последовательно выводятся на экран одна и та же таблица), ну и когда их количество доходит до 32 процесс прекращается с сообщением "Сообщение 217, уровень 16, состояние 1, процедура CountStud, строка 8
Превышен максимальный уровень вложенности хранимой процедуры, функции, триггера или представления (ограничение 32)."
В чем ошибка, как правильно создать, а потом вызвать процедуру, чтобы получить результат - 1 таблицу.
Заранее спасибо.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.07.2016, 14:00
Ответы с готовыми решениями:

Создание хранимой процедуры, которая создает хранимые процедуры
Написать хранимую процедуру SQL , которая будет создавать хранимые процедуры(любые) для БД.

Хранимые процедуры
Добрый день,помогите,ребят) Создаю базу данных английского чемпионата,вот столкнулся с проблемами. Не могу создать хранимую...

Хранимые процедуры
Столкнулся со странной проблемой никак не могу создать хранимую процедуру, говорит типа текстовые аргументы не допустимы. Исключая их...

4
3614 / 2135 / 756
Регистрация: 02.06.2013
Сообщений: 5,169
31.07.2016, 15:30
Цитата Сообщение от RHCP Посмотреть сообщение
В чем ошибка
В том, что у вас вызов процедуры в самой процедуре. В результате - бесконечная рекурсия.
Цитата Сообщение от RHCP Посмотреть сообщение
как правильно создать, а потом вызвать процедур
Процедуру нужно создать один раз:
T-SQL
1
2
3
4
5
6
7
8
9
USE library
GO
CREATE PROCEDURE CountStud
AS
SELECT Groups.Name, COUNT(*)
FROM Groups, Students
WHERE students.Id_Group = Groups.Id
GROUP BY Groups.Name
GO
А потом уже можно сколько угодно раз вызывать
T-SQL
1
EXECUTE CountStud
1
1 / 1 / 0
Регистрация: 11.10.2015
Сообщений: 46
31.07.2016, 15:54  [ТС]
Спасибо.
Оказалось, просто пропущено слово GO в конце процедуры, и строчка EXECUTE CountStud получилась как часть процедуры
0
 Аватар для pincet
1655 / 1154 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
01.08.2016, 11:50
Цитата Сообщение от invm Посмотреть сообщение
FROM Groups, Students
когда уже про это перестанут учить?
0
1116 / 761 / 183
Регистрация: 27.11.2009
Сообщений: 2,272
01.08.2016, 12:15
Цитата Сообщение от pincet Посмотреть сообщение
когда уже про это перестанут учить?
Пока это будет модно в Oracle, как я понимаю...
Оттуда же любовь новичков к курсорам, наверно.
И там же ещё подселкты обожают!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.08.2016, 12:15
Помогаю со студенческими работами здесь

хранимые процедуры
доброе время суток.. у меня такой вопрос: читал про компиляцию хранимых процедур и окончательно запутался(( вопрос мой такой: у меня...

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

хранимые процедуры
подскажите пожалуйста примерно как: Удаление из базы данных информации об определенном клиенте (по IdCust). Если с данным клиентом имеются...

Хранимые процедуры.....
Начнем: Есть некий сервер на нем есть х.п., как вытащить инфу о х.п. которая у которой есть входные параметры - это я знаю: SELECT...

Хранимые процедуры
Мне нужно чтобы в зависимости от выбранной страны в comboBox на форме в WindowsForm(например Россия) по этому запросу получалась таблица, в...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru