97久久精品人人澡人人爽_亚洲天堂二区_看黄a大片免费_国产欧美网站

Mysql中的count()與sum()區(qū)別詳細(xì)介紹

時(shí)間:2015-03-10 來(lái)源:文率科技博客
文率科技技術(shù)貼接著為廣大互聯(lián)網(wǎng)技術(shù)愛(ài)好者分析技術(shù)解決方案, 今天文率技術(shù)部分分享介紹Mysql中的count()與sum()區(qū)別,需要的朋友可以參考下: 首先創(chuàng)建個(gè)表說(shuō)明問(wèn)題 代碼如下: CREATE TABLE `result` ( `name` varchar(20) default NULL, `subject` varchar(20) default NULL, `score` tinyint(4) default NULL ) ENGINE=MyISAM DEFAULT CHARSET=utf8 插入一些數(shù)據(jù), 代碼如下: insert into result values ('張三','數(shù)學(xué)',90), ('張三','語(yǔ)文',50), ('張三','地理',40), ('李四','語(yǔ)文',55), ('李四','政治',45), ('王五','政治',30), ('趙六','語(yǔ)文',100), ('趙六','數(shù)學(xué)',99), ('趙六','品德',98); 要求:查詢出2門及2門以上不及格者的平均成績(jī)。 經(jīng)常會(huì)用兩種查詢語(yǔ)句有兩種: 代碼如下: select name,sum(score < 60) ,avg(score) from result group by name having sum(score<60) >=2; 代碼如下: select name ,count((score<60)!=0) as a,avg(score) from result group by name having a >=2; 兩種查詢的結(jié)果肯定是不一樣的,肯定是⑴種正確的,原因是為什么,這時(shí)你就要想了,count()函數(shù)的意義和sum函數(shù)的意義 count()函數(shù)里面的參數(shù)是列名的的時(shí)候,那么會(huì)計(jì)算有值項(xiàng)的次數(shù)。 Sum()函數(shù)里面的參數(shù)是列名的時(shí)候,是計(jì)算列名的值的相加,而不是有值項(xiàng)的總數(shù)。 對(duì)count()行數(shù)還要注意:它會(huì)計(jì)算總行數(shù)。不管你是否有值都會(huì)列入計(jì)算范圍。另外一點(diǎn):mysqlisam引擎很容易獲得總行數(shù)的統(tǒng)計(jì)。查詢速度變得更快 歸納:實(shí)際編程中統(tǒng)計(jì)總行數(shù)是經(jīng)常用到的。此時(shí)使用count(*)多處可見(jiàn)。我很少看到有人使用列名作為參數(shù):count(a)的情況。即使是這樣使用,可能其初衷也是想統(tǒng)計(jì)行數(shù)。只是不知道!這樣所造成的細(xì)微差異而錯(cuò)誤使用了"列名"的形式。

熱門文章

微信公眾帳號(hào)
微信公眾帳號(hào)
新浪微博
新浪微博

聯(lián)絡(luò)方式:

中國(guó) · 天津市河西區(qū)南京路35號(hào)亞太大廈1403室
電話:15620613686
郵編:300220