MySQL - 计算一个计数?

时间:2012-02-27 18:39:43

标签: mysql count

我正在尝试汇总我从MySQL数据库中提取的一些数据。

我正在使用的查询是:

SELECT `PUID`,`DROID_V`,`SIG_V`,`SPEED`,
COUNT(distinct IF(sourcelist.hasExtension=1,NAME,NULL)) as Ext, 
COUNT(distinct IF(sourcelist.hasExtension=0,NAME,NULL)) as NoExt,
COUNT(distinct NAME) as `All`
FROM sourcelist, main_small 
WHERE sourcelist.SourcePUID = 'My_Variable' AND main_small.NAME = sourcelist.SourceFileName 
GROUP BY `PUID`,`DROID_V`,`SIG_V`,`SPEED` ORDER BY `DROID_V` ASC, `SIG_V` ASC, `SPEED`

我想知道是否有一种计算这个结果的方法,所以我可以制作一个新的表格,它会给我看一些像:

每个不同的PUID,(不同DROID_V的计数),(不同Sig_V的计数),(NAME总命中数的总和)WHERE sourcelist.SourcePUID ='My_Variable'AND main_small.NAME = sourcelist.SourceFileName

正如你所看到的,我真的不擅长SQL!

来源表:

CREATE TABLE `t1` (
 `DROID_V` int(1) DEFAULT NULL,
 `Sig_V` varchar(7) DEFAULT NULL,
 `SPEED` varchar(4) DEFAULT NULL,
 `ID` varchar(7) DEFAULT NULL,
 `PARENT_ID` varchar(10) DEFAULT NULL,
 `URI` varchar(10) DEFAULT NULL,
 `FILE_PATH` varchar(68) DEFAULT NULL,
 `NAME` varchar(17) DEFAULT NULL,
 `METHOD` varchar(10) DEFAULT NULL,
 `STATUS` varchar(14) DEFAULT NULL,
 `SIZE` int(10) DEFAULT NULL,
 `TYPE` varchar(10) DEFAULT NULL,
 `EXT` varchar(4) DEFAULT NULL,
 `LAST_MODIFIED` varchar(10) DEFAULT NULL,
 `EXTENSION_MISMATCH` varchar(32) DEFAULT NULL,
 `MD5_HASH` varchar(10) DEFAULT NULL,
 `FORMAT_COUNT` varchar(10) DEFAULT NULL,
 `PUID` varchar(15) DEFAULT NULL,
 `MIME_TYPE` varchar(24) DEFAULT NULL,
 `FORMAT_NAME` varchar(10) DEFAULT NULL,
 `FORMAT_VERSION` varchar(10) DEFAULT NULL,
 `INDEX` int(11) NOT NULL AUTO_INCREMENT,
 PRIMARY KEY (`INDEX`)
) ENGINE=MyISAM AUTO_INCREMENT=960831 DEFAULT CHARSET=utf8

示例记录:

5;"v37";"slow";"10266";;"file:";"V1-FL425817.tif";"V1-FL425817.tif";"BINARY_SIG";"MultipleIdenti";"20603284";"FILE";"tif";"2008-11-03";;;;"fmt/7";"image/tiff";"Tagged Ima";"3";"191977"
5;"v37";"slow";"10268";;"file:";"V1-FL425817.tif";"V1-FL425817.tif";"BINARY_SIG";"MultipleIdenti";"20603284";"FILE";"tif";"2008-11-03";;;;"fmt/8";"image/tiff";"Tagged Ima";"4";"191978"
5;"v37";"slow";"10269";;"file:";"V1-FL425817.tif";"V1-FL425817.tif";"BINARY_SIG";"MultipleIdenti";"20603284";"FILE";"tif";"2008-11-03";;;;"fmt/9";"image/tiff";"Tagged Ima";"5";"191979"
5;"v37";"slow";"10270";;"file:";"V1-FL425817.tif";"V1-FL425817.tif";"BINARY_SIG";"MultipleIdenti";"20603284";"FILE";"tif";"2008-11-03";;;;"fmt/10";"image/tiff";"Tagged Ima";"6";"191980"

1 个答案:

答案 0 :(得分:1)

当然可以做一些像

这样的事情
Select Count(*) From (Select * From SomeTable) adummynamesoSqlParserDoesntgetupset

所以在FROM给它一个唯一名称之后将你的查询放在括号中,你就可以像对待表或视图一样对待它。