次のクエリで多くの頭痛の種を抱えています。私が信じている問題は、AND 部分から返された結果が重複していることです。Mysql は以下のクエリに対して 14 の結果を返しますが、現実的には 2 つの異なる結果だけです。
select date_format(published,'%Y-%m'),severity,count(severity)
FROM nvdcve
LEFT JOIN nvdproducts USING(cve_id)
where (published >= '2013-06-01')
AND (
(nvdproducts.company='linux' and nvdproducts.product='linux_kernel
AND nvdproducts.version IN (SELECT Kernel from Versions.VIEW_kernel))
OR (nvdproducts.company='apache' and nvdproducts.product='http_server'
AND nvdproducts.version IN (SELECT Httpd from Versions.VIEW_httpd))
OR (nvdproducts.company='sendmail' and nvdproducts.product='sendmail' AND nvdproducts.version IN (SELECT Sendmail from Versions.VIEW_sendmail))
OR (nvdproducts.company='mysql' and nvdproducts.product='mysql' AND nvdproducts.version IN (SELECT Mysqld from Versions.VIEW_mysqld))
OR (nvdproducts.company='proftpd' and nvdproducts.product='proftpd' AND nvdproducts.version IN (SELECT Proftpd from Versions.VIEW_proftpd))
OR (nvdproducts.company='perl' and nvdproducts.product='perl' AND nvdproducts.version IN (SELECT Perl from Versions.VIEW_perl))
OR (nvdproducts.company='openssl' and nvdproducts.product='openssl' AND nvdproducts.version IN (SELECT Sslinuse from Versions.VIEW_sslinuse))
)
group by date_format(published,'%Y-%m'),severity;
この要約クエリは、この結果を提供します。
+--------------------------------+----------+-----------------+
| date_format(published,'%Y-%m') | severity | count(severity) |
+--------------------------------+----------+-----------------+
| 2013-06 | MEDIUM | 14 |
+--------------------------------+----------+-----------------+
私が得ることができる最も近いのは行を取得することですが、カウントを失い、cve_id を追加します。これは私が望むものではありません。
select distinct cve_id,date_format(published,'%Y-%m'),severity
FROM nvdnew.nvdcve
LEFT JOIN nvdproducts USING(cve_id)
where (published > '2013-05-31')
and published < '2013-07-01'
AND (
(nvdproducts.company='linux' and nvdproducts.product='linux_kernel' AND nvdproducts.version IN (SELECT Kernel from Versions.VIEW_kernel))
OR (nvdproducts.company='apache' and nvdproducts.product='http_server' AND nvdproducts.version IN (SELECT Httpd from Versions.VIEW_httpd))
OR (nvdproducts.company='sendmail' and nvdproducts.product='sendmail' AND nvdproducts.version IN (SELECT Sendmail from Versions.VIEW_sendmail))
OR (nvdproducts.company='mysql' and nvdproducts.product='mysql' AND nvdproducts.version IN (SELECT Mysqld from Versions.VIEW_mysqld))
OR (nvdproducts.company='proftpd' and nvdproducts.product='proftpd' AND nvdproducts.version IN (SELECT Proftpd from Versions.VIEW_proftpd))
OR (nvdproducts.company='perl' and nvdproducts.product='perl' AND nvdproducts.version IN (SELECT Perl from Versions.VIEW_perl))
OR (nvdproducts.company='openssl' and nvdproducts.product='openssl' AND nvdproducts.version IN (SELECT Sslinuse from Versions.VIEW_sslinuse))
)
order by published;
これが結果です。
+---------------+--------------------------------+----------+
| cve_id | date_format(published,'%Y-%m') | severity |
+---------------+--------------------------------+----------+
| CVE-2013-2128 | 2013-06 | MEDIUM |
| CVE-2013-1862 | 2013-06 | MEDIUM |
+---------------+--------------------------------+----------+
2 rows in set (0.00 sec)