Просмотр полной версии : Помогите с SQL запросом плииз!
prt, ser поля по которым можно узнать какая группа к какой относится
select * from TOV ORDER BY prt
не так все просто.. В этом случае выдет вот так:
Табачные изделие
Элитная группа сигарет
Хреновая группа сигарет
LM
Winston
Palament
Петр1
Prima
верно, не обратил внимание как нужно вывести
а чо LM и Winston, это элитные сиги чтоле? незнал
и зачем дерево хранить в одной таблице? куда удобней будет хранить данные в 3 таблицах
это для примера привел
Вот такая база.. Из-за одного запроса делить в таблицы не охота, там 100500 записей.. изначально так была.
вывести так как тебе надо, вряд ли получится. А как ты понимаешь какая строка к какому уровню дерева относится?
Вот смотри, у "Табачные изделия" ser=2. Все записи, у которых prt=2 отностся в "Табачные изделия". Вот у "Элитная группа сигарет" prt=2, значит она относится "Табачные изделия" .
Сделать можно, был скрипт, но благополучно проёбан..
select *
from TOV
where prt = 2
selectdo
select *
from tov
where ser = prt
selectdo
// здесь куда тебе нужно сохранить данные
endselect
endselect
два вложенных запроса, возможно для выполнения 2 запроса (вложенного) придётся использовать алиас.
сперва находим записи которые относятся ко 2 уровню дерева(1 запрос), потом находим записи которые относятся к 3 уровню (2 запрос).
Спасибо, попробую. Результат сохранятся не будет, запрос будет запущен в IBexpert и там же выводиться. Кстати, там уровней много, просто я в примере привел 3 уровня. Надо как то циклически сделать
там табачные изделия, спиртоводочные, мясные изделия и все так же делятся на подгруппы.
вложенные запросы делай тогда в цикле, когда не найдёт подходящую запись значит последний уровень, а лучше точно узнать из скольки уровней состоит дерево
а нельзя это сделать через groupby ?
под какой SQL то? используй рекурсию
sql server 2003 кажись. А как рекурсию? Напишите код плиз, я сам пока не очень понимаю :(
sql server 2003 не существует. набей в гугле - SQL рекурсия. хотя бы
http://habrahabr.ru/post/43955/
нашел кажись пример
http://www.infocity.com.ua/db/content/db077.phtml
но как его использовать под свою задачу?
ребят, помогите!! Очень надо, кровь из носу до утра надо сделать :( хелпми
я ж тебе по русски сказал что делать
WITH
Rec (ser, prt, name, pathstr)
AS (
SELECT ser, prt, name, cast(ser as nvarchar(max)) FROM TOV WHERE prt=1
UNION ALL
SELECT TOV.ser, TOV.prt, TOV.name, Rec.pathstr + '_'+cast(TOV.ser as nvarchar(max)) FROM TOV INNER JOIN Rec ON Rec.ser = TOV.prt
)
SELECT * FROM Rec ORDER BY pathstr