데이터베이스에서 쉼표로 구분된 열에 대한 쿼리를 최적화하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-10-30 15:03:03
원래의
158명이 탐색했습니다.

How to Optimize Queries for Comma-Separated Columns in Databases?

쉼표로 구분된 열에 대한 쿼리 최적화

데이터베이스 테이블에는 종종 쉼표로 구분된 값 목록이 있는 열이 포함되어 있어 특정 항목을 쿼리할 때 문제가 발생합니다. 가치. 다음 형식의 "CATEGORIES" 열이 있는 테이블을 생각해 보세요.

ID | CATEGORIES
---------------
1  | c1
2  | c2,c3
3  | c3,c2
4  | c3
5  | c4,c8,c5,c100
로그인 후 복사

특정 범주를 검색하려면 처음에 LIKE 문을 선택할 수 있습니다.

SELECT id FROM table WHERE categories LIKE '%c2%'; -- Returns rows 2 and 3
로그인 후 복사

그러나 LIKE 문은 쉼표로 구분된 열의 ​​경우 비효율적일 수 있습니다. Oracle의 FIND_IN_SET() 함수는 적절한 대안처럼 보일 수 있지만 Oracle 10g에서는 사용할 수 없습니다.

보다 최적의 접근 방식은 적절한 와일드카드와 함께 LIKE를 사용하는 것입니다.

SELECT 
  * 
FROM
  YourTable 
WHERE 
  ',' || CommaSeparatedValueColumn || ',' LIKE '%,SearchValue,%'
로그인 후 복사

이 쿼리는 정확한 일치를 보장하기 위해 검색 값 주위에 쉼표를 추가합니다. 그러나 LIKE 사용으로 인해 여전히 속도가 느려질 수 있습니다.

가장 뛰어난 솔루션은 데이터를 교차 연결을 통해 별도의 테이블로 재구성하여 쉼표로 구분된 열의 ​​제한을 피하고 쿼리 성능을 크게 향상시키는 것입니다.

위 내용은 데이터베이스에서 쉼표로 구분된 열에 대한 쿼리를 최적화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!