|
|
|
Как произвести иерархический поиск
|
|||
|---|---|---|---|
|
#18+
Есть таблица следующей структуры: ID, Parent, Name, ... В поле Parent хранится значение ID родительской записи, для записи самого верхнего уровня(в иерархии) Parent=0. Как создать запрос, который бы возвращал child'ов всех уровней для определенной записи. Пример: имеем таблицу 1 0 Top level 2 1 Something 1 3 2 Something 1.1 4 2 Something 1.2 5 4 Something 1.2.1 6 4 Something 1.2.2 7 1 Something 2 8 7 Something 2.1 9 7 Something 2.2 Тогда для записи ID=2 запрос должен выдать 3 2 Something 1.1 4 2 Something 1.2 5 4 Something 1.2.1 6 4 Something 1.2.2 Если кто-то сталкивался с этой проблемой или знает, как ее решить, буду очень признателен за ответ. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 14.08.2001, 10:42 |
|
||
|
Как произвести иерархический поиск
|
|||
|---|---|---|---|
|
#18+
Судя по твоему примеру имеет смысл прочитать http://www.osp.ru/win2000/sql/2001/05/968.htm Или воспользоваться обычным LIKE, например: DECLARE @Level SET @Level = 2 SELECT * FROM Table1 t WHERE Name LIKE 'Something %' + REPLICATE('.%', @Level - 1) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 14.08.2001, 11:04 |
|
||
|
|

start [/forum/topic.php?fid=46&msg=32011734&tid=1825889]: |
0ms |
get settings: |
10ms |
get forum list: |
18ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
65ms |
get topic data: |
7ms |
get forum data: |
2ms |
get page messages: |
25ms |
get tp. blocked users: |
1ms |
| others: | 278ms |
| total: | 414ms |

| 0 / 0 |
