질문:
다음 구조의 MySQL 데이터베이스 테이블이 주어졌습니다.
table id INT NOT NULL PRIMARY KEY data .. next_id INT NULL
클라이언트측 처리에 의존하지 않고 데이터베이스 쿼리를 사용하여 연결된 목록 순서로 데이터를 검색할 수 있습니까?
답변:
안타깝게도 MySQL은 연결된 목록 데이터를 효율적으로 검색하는 데 필요한 재귀 쿼리를 지원하지 않습니다. 이 문제는 관계형 데이터베이스의 트리 구조를 나타내는 것과 유사합니다.
대체 접근 방식:
트리형 데이터베이스를 저장하고 검색하는 대체 방법에 대해서는 다음 질문을 참조하세요. 관계형 데이터베이스 시스템의 데이터:
깊이가 제한된 쿼리:
쿼리 결과의 깊이를 제한하려면 다음 접근 방식을 사용할 수 있습니다. 성능 저하:
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!