쿼리는 솔루션의 일부입니다. 이 쿼리를 인라인보기로 사용하여 두 개 이상의 방문 페이지가있는 키워드를 식별하십시오. 해당 쿼리의 결과를 원래 테이블로 다시 결합하십시오.
SELECT t.keyword
, t.landing_page
FROM (-- keyword with more than one landing page
SELECT r.keyword
FROM search_data r
GROUP BY r.keyword
HAVING COUNT(DISTINCT r.landing_page) > 1
) s
JOIN search_data t
ON t.keyword = s.keyword
GROUP BY t.keyword, t.landing_page
ORDER BY t.keyword, t.landing_page
이 방법이 유일한 방법은 아닙니다. 동일한 결과를 반환하는 다른 쿼리 패턴이 있습니다. 또 다른 방법의 예로서, 동일한 키워드 테이블의 다른 행이 존재하지만, 다른에서 landing_page 확인하는 상호 부질 사용 :
SELECT DISTINCT t.keyword, t.landing_page
FROM search_data t
WHERE EXISTS (SELECT 1
FROM search_data r
WHERE r.keyword = t.keyword
AND NOT (r.landing_page <=> t.landing_page)
)
ORDER BY t.keyword, t.landing_page
후속
시범 설정 :
CREATE TABLE search_data (keyword VARCHAR(10), landing_page VARCHAR(80))
;
CREATE INDEX search_data_IX1 ON search_data (keyword, landing_page)
;
INSERT INTO search_data (keyword, landing_page) VALUES
('orange','https://www.example.co.uk/')
,('apple','https://www.example.co.uk/')
,('pear','https://www.example.co.uk/')
,('apple','https://www.example.co.uk/')
,('apple','https://www.example.co.uk/landing-page')
;
쿼리 1
EXPLAIN
SELECT t.keyword
, t.landing_page
FROM (-- keyword with more than one landing page
SELECT r.keyword
FROM search_data r
GROUP BY r.keyword
HAVING COUNT(DISTINCT r.landing_page) > 1
) s
JOIN search_data t
ON t.keyword = s.keyword
GROUP BY t.keyword, t.landing_page
ORDER BY t.keyword, t.landing_page
-- id select_type table type possible_keys key key_len ref rows Extra
-- ------ ----------- ---------- ------ --------------- --------------- ------- ------ ------ ------------------------
-- 1 PRIMARY <derived2> system (NULL) (NULL) (NULL) (NULL) 1
-- 1 PRIMARY t ref search_data_IX1 search_data_IX1 13 const 2 Using where; Using index
-- 2 DERIVED r index (NULL) search_data_IX1 96 (NULL) 5 Using index
을 EXPLAIN
쿼리 실행 한
SELECT t.keyword
, t.landing_page
FROM (-- keyword with more than one landing page
SELECT r.keyword
FROM search_data r
GROUP BY r.keyword
HAVING COUNT(DISTINCT r.landing_page) > 1
) s
JOIN search_data t
ON t.keyword = s.keyword
GROUP BY t.keyword, t.landing_page
ORDER BY t.keyword, t.landing_page
-- keyword landing_page
-- ------- --------------------------------------
-- apple https://www.example.co.uk/
-- apple https://www.example.co.uk/landing-page
쿼리 2
EXPLAIN
SELECT DISTINCT t.keyword, t.landing_page
FROM search_data t
WHERE EXISTS (SELECT 1
FROM search_data r
WHERE r.keyword = t.keyword
AND NOT (r.landing_page <=> t.landing_page)
)
ORDER BY t.keyword, t.landing_page
-- id select_type table type possible_keys key key_len ref rows Extra
-- ------ ------------------ ------ ------ --------------- --------------- ------- -------------- ------ -------------------------------------
-- 1 PRIMARY t range (NULL) search_data_IX1 96 (NULL) 6 Using where; Using index for group-by
-- 2 DEPENDENT SUBQUERY r ref search_data_IX1 search_data_IX1 13 test.t.keyword 1 Using where; Using index
설명 쿼리 실행이
SELECT DISTINCT t.keyword, t.landing_page
FROM search_data t
WHERE EXISTS (SELECT 1
FROM search_data r
WHERE r.keyword = t.keyword
AND NOT (r.landing_page <=> t.landing_page)
)
ORDER BY t.keyword, t.landing_page
-- keyword landing_page
-- ------- --------------------------------------
-- apple https://www.example.co.uk/
-- apple https://www.example.co.uk/landing-page
당신이 절 –
@TheOneandOnlyChemistryBlob을 왜 HAVING의 고유 한 카운트하지 않습니다? – Barmar
@Barmar, select *에서 DISTINCT를 사용하여 필터링 할 데이터의 양을 줄이는 것이 어떻습니까? having 절에서 구별되는 경우이 시점 이전에 데이터가 이미 필터링되었을 수 있습니다. –