Аватар для kesean
292 / 291 / 108
Регистрация: 04.09.2010
Сообщений: 638

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

01.12.2016, 20:33. Показов 5129. Ответов 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru