MySQL是一種廣泛使用的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),它的強(qiáng)大和靈活性使其成為了許多企業(yè)和網(wǎng)站的首選。
MySQL有許多強(qiáng)大的語句和函數(shù),其中百分比函數(shù)是其中之一。
SELECT COUNT(*) AS total, SUM(CASE WHEN score >= 90 THEN 1 ELSE 0 END) AS excellent_count, (SUM(CASE WHEN score >= 90 THEN 1 ELSE 0 END) / COUNT(*)) * 100 AS excellent_percent, SUM(CASE WHEN score >= 80 AND score< 90 THEN 1 ELSE 0 END) AS good_count, (SUM(CASE WHEN score >= 80 AND score< 90 THEN 1 ELSE 0 END) / COUNT(*)) * 100 AS good_percent, SUM(CASE WHEN score >= 60 AND score< 80 THEN 1 ELSE 0 END) AS pass_count, (SUM(CASE WHEN score >= 60 AND score< 80 THEN 1 ELSE 0 END) / COUNT(*)) * 100 AS pass_percent, SUM(CASE WHEN score< 60 THEN 1 ELSE 0 END) AS fail_count, (SUM(CASE WHEN score< 60 THEN 1 ELSE 0 END) / COUNT(*)) * 100 AS fail_percent FROM scores;
以上SQL語句將對(duì)名為"scores"的表進(jìn)行查詢,返回總成績(jī)?nèi)藬?shù)、優(yōu)秀人數(shù)和優(yōu)秀比例、良好人數(shù)和良好比例、及格人數(shù)和及格比例、不及格人數(shù)和不及格比例。
這里使用了MySQL的CASE函數(shù),該函數(shù)根據(jù)指定的條件對(duì)數(shù)據(jù)進(jìn)行分類,然后進(jìn)行求和。
其中使用了百分比公式(SUM(CASE WHEN score >= 90 THEN 1 ELSE 0 END) / COUNT(*)) * 100,該公式將符合條件的人數(shù)求和,并除以總?cè)藬?shù),然后乘以100,即可得到百分比。
通過百分比函數(shù),我們可以輕松地分析和管理數(shù)據(jù),優(yōu)化我們的業(yè)務(wù)和決策。