Home > Database > Oracle > One article analyzing ORACLE tree structure query

One article analyzing ORACLE tree structure query

WBOY
Release: 2022-09-05 17:48:24
forward
2614 people have browsed it

This article brings you relevant knowledge about Oracle. It mainly introduces the article about parsing ORACLE tree structure query. The article expands on the topic in detail. Let’s take a look at it together. I hope Helpful to everyone.

One article analyzing ORACLE tree structure query

Recommended tutorial: "Oracle Video Tutorial"

In our daily programming, we often encounter tree structures Represents, for example, organizational structures, administrative divisions, etc. These are often displayed through a table in the database. Here we take a simple administrative division table as an example. In actual use, other description fields and levels can be added to it.

#The table is associated with ID and PID to achieve tree structure storage. The table creation and data statements are as follows:

-- Create table
create table TREETEST
(
  id   NVARCHAR2(50),
  pid  NVARCHAR2(50),
  name NVARCHAR2(50)
)
Copy after login
insert into TREETEST (ID, PID, NAME) values ('1', null, '山东省');
insert into TREETEST (ID, PID, NAME) values ('2', '1', '青岛市');
insert into TREETEST (ID, PID, NAME) values ('3', '1', '烟台市');
insert into TREETEST (ID, PID, NAME) values ('4', null, '河南省');
insert into TREETEST (ID, PID, NAME) values ('5', null, '河北省');
insert into TREETEST (ID, PID, NAME) values ('6', '2', '市南区');
insert into TREETEST (ID, PID, NAME) values ('7', '2', '市北区');
insert into TREETEST (ID, PID, NAME) values ('8', '2', '即墨市');
Copy after login

How to query the tree structure? Oracle provides recursive query for query. The basic syntax is as follows:

SELECT [Column]…..
  FEOM [Table]
  WHERE Conditional1
  START WITH Conditional2
  CONNECT BY PRIOR Conditional3
  ORDER BY [Column]
Copy after login

Description:

  • Condition 1---Filter conditions, for all Returned records are filtered.
  • Condition 2---The limiting condition of the root node. Of course, you can also relax the permissions to obtain multiple root nodes, that is, obtain multiple trees
  • Condition 3---The link condition, the purpose is Give what is the relationship between father and son, and perform a recursive query based on this relationship (in the above table, ID=PID)
  • Sort---Sort all returned records

Let’s look at specific examples below:

1. Query all sub-nodes under Shandong Province

SELECT *
  FROM TREETEST t
 START WITH t.PID=1
CONNECT BY PRIOR t.ID = t.PID
Copy after login

where the ID is 1 is the node of Shandong Province, and the query results are as follows:

#2. Query the next-level child node of Qingdao City (note the difference from the above, all Child nodes and next-level child nodes)

One article analyzing ORACLE tree structure query

3. If you need to connect Qingdao City, Shandong Province, etc. to display, you can use SYS_CONNECT_BY_PATH to achieve this

SELECT t.ID, SYS_CONNECT_BY_PATH(t.NAME, '\') AS INDU_NAME
  FROM TREETEST t
 START WITH t.PID IS NULL
CONNECT BY PRIOR t.ID = t.PID
Copy after login

The query results are as follows:

4. In the same way, you can also proceed from bottom to top. Query

SELECT *
  FROM TREETEST t
 START WITH t.ID=8
CONNECT BY t.ID = PRIOR t.PID
Copy after login

Recommended tutorial: "Oracle Video Tutorial"

The above is the detailed content of One article analyzing ORACLE tree structure query. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:jb51.net
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template