Home » RDBMS Server » Server Administration » Complex hierarchical query - how to?
Complex hierarchical query - how to? [message #372218] Fri, 19 January 2001 07:26
Balazs VISSY
Messages: 17
Registered: January 2001
Junior Member
In my recent work I’ve encountered the following problem:

The scheme:
~~~~~~~~~~~

There is a table TASKS having the columns as (each column has the type NUMBER):

ID
OPERATION_ID
CREATION_ORDER
SUB_OPERATION_ID
TASK_TYPE_ID

The ID is a primary key on the table.
The OPERATION_ID groups the task into operations.
The CREATION_ORDER defines a partial-order-relation on the TASKS for each OPERATION_ID (if the values for two records are equals they can be executed concurrently).
The SUB_OPERATION_ID works as an “include” and refers to the OPERATION_ID of this same table (here is the recursion! :-)).
The TASK_TYPE_ID is a foreign key to the to-be-executed task description.

The last two fields are excluding each other! (In other words: there is EXACTLY one of them being not null!)

The problem:
~~~~~~~~~~~~

For a given OPERATION_ID, I have to give back the graph of tasks in the form:

PARENT_ID
ID
TASK_TYPE_ID

where the first two columns refer to the ID field of the TASKS table. (PARENT_ID is NULL for the root tasks).

Restrictions and other information:
1. The number of rows affected in the query is a few dozens (not more than 100).
2. The whole table contains a few thousands of rows.
3. The algorithm could work in parallel and distributed environment.
4. Time is not essential while it is not more than a few seconds.
5. I cannot use tables for storing temporary data.

The drawback:
~~~~~~~~~~~~~

Take this example:

ID OP_ID CR_OR SUBO TASK
1 1 0 1
2 1 1 2
3 1 1 3
4 1 2 2
5 2 0 3
6 2 1 4
7 3 0 4
8 4 0 5

The result should be:

PAR ID TASK
- 1 1
1 5 3
1 7 4
5 8 5
7 4 2
8 4 2

The problems:

1. In the result, the parent not always the immediate ancestor in the original database, because all the sub-operation calls removed from the graph. For example, the 1->2->5->6->8->4 is reduced from 1->5->8->4.
2. It is not a tree. There could be more than one parent of any node, so I could not take the parent by a stored function.

I tried a dozen of ways, using START WITH ... CONNECT BY, but either received wrong result, exceeded the time threshold or bumped into SQL restrictions.

Thank you for any idea,
Balazs VISSY
Previous Topic: Complex hierarchical query - how to?
Next Topic: decode in control file
Goto Forum:
  


Current Time: Fri Jan 03 11:43:16 CST 2025