>데이터 베이스 >MySQL 튜토리얼 >단일 쿼리로 여러 데이터베이스 테이블에서 관련 레코드를 검색하는 방법은 무엇입니까?

단일 쿼리로 여러 데이터베이스 테이블에서 관련 레코드를 검색하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-29 19:18:11621검색

How to Retrieve Related Records from Multiple Database Tables in a Single Query?

관계를 기반으로 여러 레코드 검색

관계가 있는 데이터베이스 테이블을 처리할 때 일반적인 작업은 관계를 기반으로 여러 테이블에서 정보를 검색하는 것입니다. 특정 관계. 예를 들어 하나의 조직에 여러 명의 직원이 있을 수 있는 조직과 직원이라는 두 테이블을 생각해 보세요. 목표는 단일 레코드 세트에서 모든 직원의 이름을 포함하여 특정 조직에 대한 모든 정보를 검색하는 것입니다.

데이터베이스별 솔루션

이 작업에 대한 적절한 접근 방식은 사용 중인 데이터베이스 시스템에 따라 다릅니다. 일부 인기 있는 데이터베이스 시스템은 여러 값을 단일 문자열로 결합하는 프로세스인 그룹 연결을 용이하게 할 수 있는 특정 기능을 제공합니다.

  • MySQL: GROUP_CONCAT 함수를 사용하여 조직을 기준으로 한 직원의 이름 ID.
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
  • PostgreSQL: PostgreSQl 9.0은 직원의 이름에 쉼표를 추가하는 데 사용할 수 있는 그룹 연결을 위한 STRING_AGG 함수를 제공합니다. 공간 구분 기호.
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
  • Oracle: Oracle은 값 연결을 위해 LISTAGG 함수를 제공합니다.
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
  • MS SQL Server: MS SQL Server 2017 및 나중에 그룹 연결을 위한 STRING_AGG 기능을 도입했습니다.
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

폴백 솔루션

기본 그룹 연결 기능이 없는 데이터베이스 시스템 또는 지원되는 이전 버전의 경우 데이터베이스의 경우 대체 솔루션을 사용할 수 있습니다.

  • 다음과 같은 저장 프로시저를 만듭니다. 조직의 ID를 승인하고 연결된 직원 이름을 반환합니다. 이 저장 프로시저를 쿼리에 통합하세요.
select 
  o.ID, o.Address, o.OtherDetails,
  MY_CUSTOM_GROUP_CONCAT_PROCEDURE( o.ID ) as Employees
from 
  organization o

위 내용은 단일 쿼리로 여러 데이터베이스 테이블에서 관련 레코드를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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