예를 들어 이런 표에서 이메일과 비밀번호가 다른 레코드의 개수를 세고 싶습니다.
코드 복사 코드는 다음과 같습니다.
존재하지 않는 경우 테이블 생성 `test_users` (
`email_id` int(11) unsigned NOT NULL auto_increment,
`email` char(100) NOT NULL,
` 비밀번호` char(64) NOT NULL ,
PRIMARY KEY (`email_id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=6 ;
INSERT INTO `test_users` (` email_id`, `email`, `passwords`) 값
(1, 'jims@gmail.com', '1e48c4420b7073bc11916c6c1de226bb'),
(2, 'jims@yahoo.com.cn', '5294cef9f1bf1858ce9d7fdb62240546 ′ ),
(3 , 'default@gmail.com', '5294cef9f1bf1858ce9d7fdb62240546′),
(4, 'jims@gmail.com', ”),
(5, 'jims@gmail.com ', ”)
일반적으로 접근 방식은 다음과 같습니다
코드 복사 코드는 다음과 같습니다.
SELECT COUNT(*) FROM test_users WHERE 1 = 1 GROUP BY email,passwords
이 결과는 무엇입니까?
코드 복사 코드는 다음과 같습니다.
COUNT(*)
1
2
1
1
분명히 제가 원하는 결과는 아닙니다. 이메일과 비밀번호가 동일한 레코드 수의 합은 다음과 같습니다
코드 복사 코드는 다음과 같습니다:
SELECT COUNT(DISTINCT email,passwords) FROM `test_users` WHERE 1 = 1
물론 PHP에서는 mysql_num_rows를 사용하여 레코드 수를 얻을 수도 있지만 이는 효율적이지 않습니다.
mysql_num_rows VS COUNT 효율성 문제 분석을 참조하세요.
위의 내용을 포함하여 GROUP BY를 사용할 때 COUNT DISTINCT의 레코드 수를 계산하는 방법을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.