mysql 统计查询实例学习

发布时间:2019-10-05编辑:脚本学堂
本文介绍了mysql 统计查询的语法与实例,mysql实现统计查询,其实就是select count() from 语法用于从数据表中统计数据行数,有需要的朋友做个参考。

mysql/ target=_blank class=infotextkey>mysql数据库中,统计数据行数:
select count() from 语法用于从数据表中统计数据行数。

语法:
select count(column) from tb_name
该 sql 语法用于统计某一字段的数据行数,count() 内不能是多个字段,但可以是 * 号。

例子:
 

复制代码 代码示例:

<?php
$conn = @mysql_connect("localhost","root","root123");
if (!$conn){
die("连接数据库失败:" . mysql_error());
}

mysql_select_db("test", $conn);
$sql = "select count(uid) from user";
$row = mysql_fetch_array( mysql_query($sql) );
echo "共有用户: ",$row[0]," 位";
?>

浏览器显示:
共有用户: 4 位

说明
尽管 count() 中的参数可以是某个字段名,但如果只是想统计表中的数据记录数目,从效率上考虑建议统计主键 count(id) 或直接使用 count(*) ,另外尽量避免使用列数据属性为字符类的。

例1,mysql查询统计函数中的count

题目:统计所有女生成绩大于90以上有总数
开始这样写:
 

$sql = "select 女生成绩 from use where 成绩 > 90“;
$result = mysql_query($sql);
$row = mysql_num_rows($result);echo "总数为:$row";

可是100条还行吧,如果是10000条那是不是要很慢啊!!后来一个朋友给我说用count函数,这我才想起来。

把上面的sql语句改为:
 

复制代码 代码示例:
$sql = "select count(*),女生成绩 from use group by 女生成绩 having 女生成绩 > 90";

这样查询语句就快多了

例2,单个select语句实现mysql查询统计次数
比如一个成绩单,你要查询及格得人数与不及格的人数,怎么一次查询出来?
mysql查询统计次数:
 

复制代码 代码示例:
select a.name,count_neg,count_plus from   
(select count(id) as count_plus,name from score2 where score >=60 group by name) a,  
(select count(id) as count_neg,name from score2 where score <=60 group by name) b   
where a.name=b.name  
 

即必须至少用2个语句。

mysql支持if,可以考虑用if来实现:
 

复制代码 代码示例:
select name, sum(if(score>=60,1,0)),sum(if(score<60,1,0)) from score2 group by name 

单个select语句实现mysql查询统计次数的方法简单吧。
原理就是大于60,就赋值为1,那么sum就是计数了。