목차
oracle은 어떻게 하위 노드를 재귀적으로 쿼리합니까?
데이터 베이스 Oracle Oracle에서 하위 노드를 재귀적으로 쿼리하는 방법

Oracle에서 하위 노드를 재귀적으로 쿼리하는 방법

Jan 25, 2022 pm 02:38 PM
oracle

Oracle에서는 select 문을 사용하여 하위 노드를 재귀적으로 쿼리할 수 있습니다. 이 문의 기능은 테이블 데이터에 대해 간단한 쿼리를 수행하는 것입니다. 구문은 "SELECT * FROM table name START WITH 조건 1 CONNECT BY PRIOR 조건 2입니다. WHERE 조건 3".

Oracle에서 하위 노드를 재귀적으로 쿼리하는 방법

이 튜토리얼의 운영 환경: Windows 10 시스템, Oracle 11g 버전, Dell G3 컴퓨터.

oracle은 어떻게 하위 노드를 재귀적으로 쿼리합니까?

문법 구조

SELECT ... FROM    + 表名  START WITH + 条件1 CONNECT BY PRIOR + 条件2  WHERE  + 条件3

조건 1: 루트 노드에 대한 한정문입니다. 물론, 한정 조건을 완화하여 여러 루트 노드, 즉 여러 트리를 얻을 수 있습니다. 연결 관계에서는 컬럼 외에 컬럼 표현식도 허용됩니다. START WITH 절은 선택 사항이며 검색 트리 구조의 루트 노드로 사용되는 노드를 식별하는 데 사용됩니다. 이 절이 생략되면 쿼리 조건을 만족하는 모든 행이 루트 노드로 사용된다는 의미입니다.

조건 2: 이전 레코드를 나타내기 위해 PRIOR을 사용하는 연결 조건입니다. 예를 들어 CONNECT BY PRIOR STUDENT_ID = GRADE_ID는 이전 레코드의 STUDENT_ID가 이 레코드의 GRADE_ID라는 의미입니다. , 이 레코드의 아버지는 이전 레코드입니다. CONNECT BY 절은 데이터의 각 행이 계층적 순서로 검색됨을 나타내고 테이블의 데이터가 트리 구조 관계로 연결됨을 지정합니다. PRIOR 연산자는 조인 관계의 두 열 중 하나 앞에 배치되어야 합니다. 노드 간 부모-자식 관계의 경우 PRIOR 연산자는 한쪽은 부모 노드, 다른 쪽은 자식 노드를 나타내어 트리 구조를 검색하는 순서가 하향식인지 상향식인지를 결정합니다.

조건 3: 반환된 레코드를 필터링하는 데 사용되는 필터링 조건입니다.

참고:

1. CONNECT BY PRIOR는 구조화된 쿼리에 사용됩니다.

2. START WITH... CONNECT BY PRIOR...의 기능은 테이블 내부와 외부에 트리 구조를 저장하는 것입니다.

하위 노드를 통해 루트 노드를 탐색합니다.

select * from persons.dept start with deptid=76 connect by prior paredeptid=deptid

루트 노드를 통해 하위 노드를 탐색합니다(루트 노드 제외).

select * from persons.dept start with paredeptid=0 connect by prior deptid=paredeptid

루트 노드(루트 노드 포함)를 통해 하위 노드를 탐색합니다.

select * from persons.dept start with deptid=0 connect by prior deptid=paredeptid

레벨 키워드를 통해 전달될 수 있습니다. 레벨 쿼리.

select a.*,level from persons.dept a start with paredeptid=0 connect by prior deptid=paredeptid

참고:

start with...사용법에 따라 연결, start with 뒤에 오는 것은 재귀 시드입니다.

재귀의 시드는 연결 이후의 "이전"입니다. 기본값인 경우 조건을 충족하는 시작 행만 쿼리할 수 있으며 재귀 쿼리는 수행되지 않습니다. 사전에 따라 관련성이 있으며 쿼리 방향을 나타냅니다.

연습: 하위 노드를 통해 최상위 노드 가져오기

select FIRST_VALUE(deptid) OVER (ORDER BY LEVEL DESC ROWS UNBOUNDED PRECEDING) AS firstdeptid from persons.dept start with deptid=76 connect by prior paredeptid=deptid

테이블 구조

DEPTID PAREDEPTID NAME
NUMBER NUMBER CHAR (40 Byte)

Department id 상위 부서 ID(소속 부서 ID) 부서 이름

추천 튜토리얼: "

Oracle Video Tutorial

"

위 내용은 Oracle에서 하위 노드를 재귀적으로 쿼리하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

MySQL을 제거하고 잔류 파일을 청소하는 방법 MySQL을 제거하고 잔류 파일을 청소하는 방법 Apr 29, 2025 pm 04:03 PM

MySQL을 안전하고 철저하게 제거하고 모든 잔차 파일을 정리하려면 다음 단계를 따르십시오. 1. MySQL 서비스 중지; 2. MySQL 패키지 제거; 3. 구성 파일 및 데이터 디렉토리를 정리하십시오. 4. 제거가 철저한 지 확인하십시오.

비즈니스 세계에서 오라클의 역할 비즈니스 세계에서 오라클의 역할 Apr 23, 2025 am 12:01 AM

Oracle은 데이터베이스 회사 일뿐 만 아니라 클라우드 컴퓨팅 및 ERP 시스템의 리더이기도합니다. 1. Oracle은 데이터베이스에서 클라우드 서비스 및 ERP 시스템에 이르기까지 포괄적 인 솔루션을 제공합니다. 2. OracleCloud는 AWS와 Azure에 도전하여 IAA, PAAS 및 SAAS 서비스를 제공합니다. 3. E-BusinessSuite 및 FusionApplications와 같은 Oracle의 ERP 시스템은 기업이 운영을 최적화하는 데 도움이됩니다.

Mongodb vs. Oracle : 주요 차이점 이해 Mongodb vs. Oracle : 주요 차이점 이해 Apr 16, 2025 am 12:01 AM

MongoDB는 대규모 비정형 데이터를 처리하는 데 적합하며 Oracle은 거래 일관성이 필요한 엔터프라이즈 수준의 응용 프로그램에 적합합니다. 1. MongoDB는 사용자 행동 데이터 처리에 적합한 유연성과 고성능을 제공합니다. 2. Oracle은 안정성과 강력한 기능으로 유명하며 금융 시스템에 적합합니다. 3. MongoDB는 문서 모델을 사용하고 Oracle은 관계형 모델을 사용합니다. 4. MongoDB는 소셜 미디어 응용 프로그램에 적합하지만 Oracle은 엔터프라이즈 수준의 응용 프로그램에 적합합니다.

Mongodb vs. Oracle : 필요에 맞는 올바른 데이터베이스 선택 Mongodb vs. Oracle : 필요에 맞는 올바른 데이터베이스 선택 Apr 22, 2025 am 12:10 AM

MongoDB는 구조화되지 않은 데이터 및 높은 확장 성 요구 사항에 적합한 반면 Oracle은 엄격한 데이터 일관성이 필요한 시나리오에 적합합니다. 1. MongoDB는 소셜 미디어 및 사물 인터넷에 적합한 다양한 구조물에 데이터를 유연하게 저장합니다. 2. Oracle 구조화 된 데이터 모델은 데이터 무결성을 보장하고 금융 거래에 적합합니다. 3. MongoDB는 파편을 통해 수평으로 비늘을, RAC를 통해 수직으로 오라클 스케일링됩니다. 4. MongoDB는 유지 보수 비용이 낮지 만 Oracle은 유지 보수 비용이 높지만 완전히 지원됩니다.

YI 프레임 워크에 어떤 소프트웨어가 더 좋습니까? YI 프레임 워크에 권장되는 소프트웨어 YI 프레임 워크에 어떤 소프트웨어가 더 좋습니까? YI 프레임 워크에 권장되는 소프트웨어 Apr 18, 2025 pm 11:03 PM

기사의 첫 번째 단락의 초록 : Yi 프레임 워크 응용 프로그램을 개발하기위한 소프트웨어를 선택할 때 여러 가지 요소를 고려해야합니다. Xcode 및 Android Studio와 같은 기본 모바일 애플리케이션 개발 도구는 강력한 제어 및 유연성을 제공 할 수 있지만 React Native 및 Flut 모바일 개발에 새로운 개발자의 경우 AppSheet 및 Glide와 같은 저 코드 또는 노 코드 플랫폼이 응용 프로그램을 빠르고 쉽게 구축 할 수 있습니다. 또한 AWS Amplify 및 Firebase와 같은 클라우드 서비스 제공 업체는 포괄적 인 도구를 제공합니다.

MySQL vs. Oracle : 라이센스, 기능 및 혜택 MySQL vs. Oracle : 라이센스, 기능 및 혜택 May 08, 2025 am 12:05 AM

MySQL과 Oracle의 주요 차이점은 라이센스, 기능 및 장점입니다. 1. 라이센스 : MySQL은 무료 사용을위한 GPL 라이센스를 제공하고 Oracle은 독점 라이센스를 채택합니다. 2. 기능 : MySQL에는 간단한 기능이 있으며 웹 응용 프로그램 및 중소 기업에 적합합니다. Oracle은 강력한 기능을 가지고 있으며 대규모 데이터 및 복잡한 비즈니스에 적합합니다. 3. 장점 : MySQL은 오픈 소스 무료이며 스타트 업에 적합하며 Oracle은 성능이 신뢰할 수 있으며 대기업에 적합합니다.

MySQL 및 Oracle : 성능과 확장 성 탐색 MySQL 및 Oracle : 성능과 확장 성 탐색 Apr 29, 2025 am 12:12 AM

성능과 확장 성에서 MySQL과 Oracle의 차이점은 다음과 같습니다. 1. MySQL은 중소형 데이터 세트에서 더 잘 수행되며 빠른 스케일링 및 효율적인 읽기 및 쓰기에 적합합니다. 2. Oracle은 대형 데이터 세트와 복잡한 쿼리를 처리하는 데 더 많은 장점이 있으며, 고 가용성 및 복잡한 비즈니스 논리에 적합합니다. MySQL은 마스터 슬레이브 복제 및 샤드 기술을 통해 확장되며 Oracle은 RAC를 통해 고 가용성과 확장 성을 달성합니다.

MySQL vs. Oracle : 라이센스 및 비용 이해 MySQL vs. Oracle : 라이센스 및 비용 이해 May 03, 2025 am 12:19 AM

MySQL은 소규모 및 오픈 소스 프로젝트에 GPL 및 상용 라이센스를 사용합니다. Oracle은 고성능이 필요한 기업에 상업용 라이센스를 사용합니다. MySQL의 GPL 라이센스는 무료이며 상업용 라이센스는 지불이 필요합니다. Oracle 라이센스 요금은 프로세서 또는 사용자를 기반으로 계산되며 비용은 상대적으로 높습니다.

See all articles