Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.76/25: Рейтинг темы: голосов - 25, средняя оценка - 4.76
 Аватар для kesean
292 / 291 / 108
Регистрация: 04.09.2010
Сообщений: 638

Ошибка в рекурсивном запросе

01.12.2016, 20:33. Показов 5088. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Прошу помощи.
Есть таблица
SQL
1
DECLARE @p TABLE (id INT, name NCHAR(100), obj_id CHAR(10), parent CHAR(10))
В ней данные
SQL
1
2
3
4
5
6
7
8
INSERT @p SELECT 0,'Иванов','IVA','0' /*big boss*/
INSERT @p SELECT 1,'Петров','PETR','IVA' /*Подчинен Иванову*/
INSERT @p SELECT 2,'Васечкин','VAS','IVA' /*Подчинен Иванову*/
INSERT @p SELECT 3,'Сидоров','CID','PETR' /*Подчинен Петрову*/
INSERT @p SELECT 4,'Пупкин','PUP','PETR' /*Подчинен Петрову*/
INSERT @p SELECT 5,'Гадюков','GAD','PUP' /*Подчинен Пупкину*/
INSERT @p SELECT 6,'Котов','KOT','GAD' /*Подчинен Гадюкову*/
INSERT @p SELECT 7,'Непоймикто','NONAME','KOT' /*Подчинен Котову*/
Хочу построить дерево подчинения, чтобы на выходе иметь что-то типа

Как-то так:
SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
WITH  tree (id_t, name_t, level_t, path_t)
AS (SELECT id, name, 0, name 
   FROM @p
   WHERE parent='0'
UNION ALL
   SELECT id, 
       name, 
       level_t + 1, 
       name_t + ' / ' + name 
   FROM @p 
     INNER JOIN tree ON tree.id_t = parent) 
SELECT id_t, name_t, path_t
FROM tree 
ORDER BY path_t
В итоге не совсем понятное исключение
"Incorrect syntax near the keyword 'with'. If this statement is a common table expression, an xmlnamespaces clause or a change tracking context clause, the previous statement must be terminated with a semicolon."
Как правильно создать запрос?

PS: MSSQL 2012
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.12.2016, 20:33
Ответы с готовыми решениями:

Ошибка в запросе с LIKE
procedure TForm6.Button1Click(Sender: TObject); begin ADOQuery1.Active:=false; ADOQuery1.SQL.Clear; ADOQuery1.SQL.Add('SELECT *'+...

Ошибка в запросе
Выполняю задачу на онлайн-сайте. Перечислите номера моделей любых типов, имеющих самую высокую цену по всей имеющейся в базе данных...

Ошибка в запросе
Делаю запрос на заполнение таблиц. Таблицы создал, все нормально вышло, а вот с заполнением проблема. Где ошибка? Задание: Тестирование...

2
 Аватар для kesean
292 / 291 / 108
Регистрация: 04.09.2010
Сообщений: 638
01.12.2016, 20:48  [ТС]
Так, точка с запятой перед "with" убрало ошибку
Теперь другое
Types don't match between the anchor and the recursive part in column "path_t" of recursive query "tree".
Какие типы не совпадают?
0
шапоклякистка 8-го дня
 Аватар для texnik-san
3681 / 2241 / 391
Регистрация: 26.06.2015
Сообщений: 4,647
Записей в блоге: 1
02.12.2016, 01:08
Цитата Сообщение от kesean Посмотреть сообщение
Какие типы не совпадают?
Не тот идентификатор сравниваете с parent. Не id а obj_id надо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.12.2016, 01:08
Помогаю со студенческими работами здесь

ошибка в запросе
есть часть запроса: where c.Path LIKE '%' + CAST((c1.ID IN (select ID from tbl_CompanyMission c2 where c2.ParentID =...

Ошибка в запросе
select ОкладБольничного.Оклад/30*Больничный.ДнейБольничного as Итого from Больничный, ОкладБольничного where Больничный.ОкладБольничного =...

Ошибка в запросе
Реализовать SQL запрос: - Список всех клиентов, у которых больше двух договоров. SELECT Фамилия+"+Имя+"Отчество AS ФИО ...

Ошибка в запросе
use torg_firm go SELECT postachalnik.Nazva, zakaz_tovar.Kilkist * tovar.Price FROM zakaz INNER JOIN postachalnik ON...

Ошибка в запросе
Задание:Какому поставщику было сделано больше всего заказов. Использую 2 таблицы. Нужно обязательно сделать с помощью пдзапросов, не могу...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG-файла с альфа-каналом с помощью библиотеки SDL3_image на Android
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru