源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

MySQL 统计查询实现代码

  • 时间:2020-10-28 13:00 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:MySQL 统计查询实现代码
统计数据行数 SELECT COUNT() FROM 语法用于从数据表中统计数据行数。 语法: SELECT COUNT(column) FROM tb_name 该 SQL 语法用于统计某一字段的数据行数,COUNT() 内不能是多个字段,但可以是 * 号。 例子:
[u]复制代码[/u] 代码如下:
<?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(*) ,另外尽量避免使用列数据属性为字符类的。 既然都看到这了就为大家分享两个例子吧 [b]Mysql查询统计函数中的count [/b] 今天我遇到一个题目:统计所有女生成绩大于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"; 这样查询语句就快多了  [b]单个select语句实现MySQL查询统计次数[/b] 单个select语句实现MySQL查询统计次数的方法用处在哪里呢?用处太多了,比如一个成绩单,你要查询及格得人数与不及格的人数,怎么一次查询出来? MySQL查询统计次数简单的语句肯定是这样了:
[u]复制代码[/u] 代码如下:
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来实现吧:
[u]复制代码[/u] 代码如下:
select name, sum(if(score>=60,1,0)),sum(if(score<60,1,0)) from score2 group by name 
单个select语句实现MySQL查询统计次数的方法简单吧。 原理就是大于60,就赋值为1,那么sum就是计数了。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部