집 >데이터 베이스 >MySQL 튜토리얼 >단일 쿼리로 여러 데이터베이스 테이블에서 관련 레코드를 검색하는 방법은 무엇입니까?
관계를 기반으로 여러 레코드 검색
관계가 있는 데이터베이스 테이블을 처리할 때 일반적인 작업은 관계를 기반으로 여러 테이블에서 정보를 검색하는 것입니다. 특정 관계. 예를 들어 하나의 조직에 여러 명의 직원이 있을 수 있는 조직과 직원이라는 두 테이블을 생각해 보세요. 목표는 단일 레코드 세트에서 모든 직원의 이름을 포함하여 특정 조직에 대한 모든 정보를 검색하는 것입니다.
데이터베이스별 솔루션
이 작업에 대한 적절한 접근 방식은 사용 중인 데이터베이스 시스템에 따라 다릅니다. 일부 인기 있는 데이터베이스 시스템은 여러 값을 단일 문자열로 결합하는 프로세스인 그룹 연결을 용이하게 할 수 있는 특정 기능을 제공합니다.
select o.ID, o.Address, o.OtherDetails, GROUP_CONCAT( concat(e.firstname, ' ', e.lastname) ) as Employees from employees e inner join organization o on o.org_id=e.org_id group by o.org_id
select o.ID, o.Address, o.OtherDetails, STRING_AGG( (e.firstname || ' ' || e.lastname), ', ' ) as Employees from employees e inner join organization o on o.org_id=e.org_id group by o.org_id
select o.ID, o.Address, o.OtherDetails, LISTAGG((e.firstname || ' ' || e.lastname) ,',') as Employees from employees e inner join organization o on o.org_id=e.org_id group by o.org_id
select o.ID, o.Address, o.OtherDetails, STRING_AGG((e.firstname || ' ' || e.lastname) ,',') as Employees from employees e inner join organization o on o.org_id=e.org_id group by o.org_id
폴백 솔루션
기본 그룹 연결 기능이 없는 데이터베이스 시스템 또는 지원되는 이전 버전의 경우 데이터베이스의 경우 대체 솔루션을 사용할 수 있습니다.
select o.ID, o.Address, o.OtherDetails, MY_CUSTOM_GROUP_CONCAT_PROCEDURE( o.ID ) as Employees from organization o
위 내용은 단일 쿼리로 여러 데이터베이스 테이블에서 관련 레코드를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!