>백엔드 개발 >PHP 튜토리얼 >GROUP BY COUNT DISTINCT를 사용할 때 레코드 수를 계산하는 방법

GROUP BY COUNT DISTINCT를 사용할 때 레코드 수를 계산하는 방법

WBOY
WBOY원래의
2016-07-29 08:44:571251검색

예를 들어 이런 표에서 이메일과 비밀번호가 다른 레코드의 개수를 세고 싶습니다.

코드 복사 코드는 다음과 같습니다.


존재하지 않는 경우 테이블 생성 `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 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

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