>데이터 베이스 >MySQL 튜토리얼 >MySQL은 클라이언트측 처리 없이 연결 목록 데이터를 검색할 수 있습니까?

MySQL은 클라이언트측 처리 없이 연결 목록 데이터를 검색할 수 있습니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-04 08:38:30874검색

Can MySQL Retrieve Linked List Data Without Client-Side Processing?

MySQL 데이터베이스에서 연결 목록 데이터 검색

질문:

다음 구조의 MySQL 데이터베이스 테이블이 주어졌습니다.

table
    id INT NOT NULL PRIMARY KEY
    data ..
    next_id INT NULL

클라이언트측 처리에 의존하지 않고 데이터베이스 쿼리를 사용하여 연결된 목록 순서로 데이터를 검색할 수 있습니까?

답변:

안타깝게도 MySQL은 연결된 목록 데이터를 효율적으로 검색하는 데 필요한 재귀 쿼리를 지원하지 않습니다. 이 문제는 관계형 데이터베이스의 트리 구조를 나타내는 것과 유사합니다.

대체 접근 방식:

트리형 데이터베이스를 저장하고 검색하는 대체 방법에 대해서는 다음 질문을 참조하세요. 관계형 데이터베이스 시스템의 데이터:

  • "플랫 테이블을 트리로 구문 분석하는 가장 효율적이고 우아한 방법은 무엇입니까?"
  • "재귀 SQL을 만드는 것이 가능합니까? query ?"

깊이가 제한된 쿼리:

쿼리 결과의 깊이를 제한하려면 다음 접근 방식을 사용할 수 있습니다. 성능 저하:

SELECT * FROM mytable t1
 LEFT JOIN mytable t2 ON (t1.next_id = t2.id)
 LEFT JOIN mytable t3 ON (t2.next_id = t3.id)
 LEFT JOIN mytable t4 ON (t3.next_id = t4.id)
 LEFT JOIN mytable t5 ON (t4.next_id = t5.id)
 LEFT JOIN mytable t6 ON (t5.next_id = t6.id)
 LEFT JOIN mytable t7 ON (t6.next_id = t7.id)
 LEFT JOIN mytable t8 ON (t7.next_id = t8.id)
 LEFT JOIN mytable t9 ON (t8.next_id = t9.id)
 LEFT JOIN mytable t10 ON (t9.next_id = t10.id);

연결된 목록마다 결과가 단일 행으로 반환되지만 쿼리 성능이 느려집니다.

위 내용은 MySQL은 클라이언트측 처리 없이 연결 목록 데이터를 검색할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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