400-915-1135
详细

MySQL多列求和、求平均值,统计求总数/平均数和今日总数/平均数(php、mysql查询当天,本周,本月的用法)

发表日期:2022-07-31 13:50:10   作者来源:超级管理员   浏览:0

最近帮一个朋友写一个打分系统,就是他手下有一批讲师,讲师讲完课后,学员要对讲师打分,对10个问题打1-5分。然后后台统计所有讲师的总得分,总平均分,今日得分,今日平均分情况,并排名。 本着一条SQL语句解决的办法,我们可以写出下面的SQL语句 我们先看打分记录表,目前我们设计得很简单,10个问题,对应10个字段(因为对方需求很简单,且不常变,如果经常变,建议弄一个关联表)我们可以对上面的需求进行分解 1、统计所有讲师的总分

  1. SELECT

  2.         teacher_id,

  3.         sum( q1 + q2 + q3 + q4 + q5 + q6 + q7 + q8 + q9 + q10 ) AS total

  4. FROM

  5.     sens_record

  6. GROUP BY

  7.     teacher_id

  2、统计所有讲师的平均分

  1. SELECT

  2.       teacher_id,

  3.       sum( q1 + q2 + q3 + q4 + q5 + q6 + q7 + q8 + q9 + q10 ) / count( * ) AS avg

  4. FROM

  5.     sens_record

  6. GROUP BY

  7.     teacher_id

  3、统计今天的数据 只需要 WHERE 后面加以下条件即可

  1. to_days( create_time ) = to_days( now( ) )

  4、如果为 NULL 就设置为 0 可以用

  1. IFNULL( 字段, 0 )

  5、查询所有的讲师,然后左连接添加今日所有讲师得分

  1. SELECT

  2.     t.id,

  3.     t.NAME,

  4.     IFNULL( today.total, 0 ) AS todayTotal

  5. FROM

  6.     sens_teacher t

  7. LEFT JOIN (

  8.     SELECT

  9.         teacher_id,

  10.         sum( q1 + q2 + q3 + q4 + q5 + q6 + q7 + q8 + q9 + q10 ) AS total

  11.     FROM

  12.         sens_record

  13.     WHERE

  14.         to_days( create_time ) = to_days( now( ) )

  15.     GROUP BY

  16.         teacher_id

  17.     ) AS today

  18. ON t.id = today.teacher_id

    最后完整的 统计所有讲师的总得分,总平均分,今日得分,今日平均分情况,并排名

  1. SELECT

  2.     t.id,

  3.     t.NAME,

  4.     IFNULL( total.total, 0 ) AS total,

  5.     IFNULL( ROUND(total.avg), 0 ) AS avg,

  6.     IFNULL( today.total, 0 ) AS todayTotal,

  7.     IFNULL( ROUND(today.avg), 0 ) AS todayAvg

  8. FROM

  9.     sens_teacher t

  10.     -- 获得所有的总分和平均分

  11.     LEFT JOIN (

  12.     SELECT

  13.         teacher_id,

  14.         sum( q1 + q2 + q3 + q4 + q5 + q6 + q7 + q8 + q9 + q10 ) AS total,

  15.         sum( q1 + q2 + q3 + q4 + q5 + q6 + q7 + q8 + q9 + q10 ) / count( * ) AS avg

  16.     FROM

  17.         sens_record

  18.     GROUP BY

  19.         teacher_id

  20.     ) AS total ON t.id = total.teacher_id


  21.     -- 获得今天的总分和平均分

  22.     LEFT JOIN (

  23.     SELECT

  24.         teacher_id,

  25.         sum( q1 + q2 + q3 + q4 + q5 + q6 + q7 + q8 + q9 + q10 ) AS total,

  26.         sum( q1 + q2 + q3 + q4 + q5 + q6 + q7 + q8 + q9 + q10 ) / count( * ) AS avg

  27.     FROM

  28.         sens_record

  29.     WHERE

  30.         to_days( create_time ) = to_days( now( ) )

  31.     GROUP BY

  32.         teacher_id

  33.     ) AS today ON t.id = today.teacher_id


  34. WHERE t.type = 1

  35. ORDER BY total DESC

结果如下


方式二

mysql查询当天,本周,本月的数据(字段是时间戳)

//其中 video 是表名;
//createtime 是字段;
//
//数据库time字段为时间戳
//
//查询当天:

$start = date('Y-m-d 00:00:00');
$end = date('Y-m-d H:i:s');
SELECT * FROM `table_name` WHERE `time` >= unix_timestamp( '$start' ) AND `time` <= unix_timestamp( '$end' )

//查询本周:

SELECT yearweek( '2011-04-17 15:38:22',1 ) //结果是201115
SELECT yearweek( '2011-04-17 15:38:22' ) //结果是201116
//yearweek的第2个参数设置为1的原因是,中国人习惯把周1作为本周的第一天
//另外补充下:
//2011-04-17 是周日。
SELECT dayofweek( '2011-04-17 15:38:22' )// 查询出的是1,把礼拜天作为一周的第一天。
SELECT dayofweek( '2011-04-18 15:38:22' ) //查询出的是2
SELECT weekday( '2011-04-17 15:38:22' )// 查询出的是6,
SELECT weekday( '2011-04-18 15:38:22' )// 查询出的是0,
//所以建议使用weekday,查询出来的结果+1就可以了,就比较符合国人的习惯了。

SELECT * FROM `table_name` WHERE YEARWEEK( FROM_UNIXTIME( `time`, '%Y-%m-%d %H:%i:%s' ) ,1) = YEARWEEK( now( ),1 )

//查询本月:

$start = date('Y-m-01 00:00:00');
$end = date('Y-m-d H:i:s');
SELECT * FROM `table_name` WHERE `time` >= unix_timestamp('”.$start.”') AND `time` <= unix_timestamp('$end')

//查询本年:

$start = date('Y-01-01 00:00:00');
$end = date('Y-m-d H:i:s');
SELECT * FROM `table_name` WHERE `time` >= unix_timestamp( '$start' ) AND `time` <= unix_timestamp( '$end' )


php 获取今日、昨日、上周、本月的起始时间戳和结束时间

<?php
//<!--php 获取今日、昨日、上周、本月的起始时间戳和结束时间戳的方法,主要使用到了 php 的时间函数 mktime()。-->


//1、php获取今日开始时间戳和结束时间戳 

$beginToday = mktime(0,0,0,date('m'),date('d'),date('Y'));
$endToday = mktime(0,0,0,date('m'),date('d')+1,date('Y'))-1;

echo $beginToday.'---'.$endToday;
echo '<br/>';
//2、php获取昨日起始时间戳和结束时间戳

$beginYesterday = mktime(0,0,0,date('m'),date('d')-1,date('Y'));
$endYesterday = mktime(0,0,0,date('m'),date('d'),date('Y'))-1;

echo $beginYesterday.'---'.$endYesterday;
echo '<br/>';
//3、php获取上周起始时间戳和结束时间戳

$beginLastweek=mktime(0,0,0,date('m'),date('d')-date('w')+1-7,date('Y'));
$endLastweek=mktime(23,59,59,date('m'),date('d')-date('w')+7-7,date('Y'));

echo $beginLastweek.'---'.$endLastweek;
echo '<br/>';

//4、php获取本月起始时间戳和结束时间戳

$beginThismonth=mktime(0,0,0,date('m'),1,date('Y'));
$endThismonth=mktime(23,59,59,date('m'),date('t'),date('Y'));

echo $beginThismonth.'---'.$endThismonth;
echo '<br/>';


//PHP mktime() 函数用于返回一个日期的 Unix 时间戳。
//语法:mktime(hour,minute,second,month,day,year,is_dst)
//
//参数        描述
//hour        可选。规定小时。
//minute        可选。规定分钟。
//second        可选。规定秒。
//month        可选。规定用数字表示的月。
//day        可选。规定天。
//year        可选。规定年。在某些系统上,合法值介于 1901 - 2038 之间。不过在 PHP 5 中已经不存在这个限制了。
//is_dst可选。如果时间在日光节约时间(DST)期间,则设置为1,否则设置为0,若未知,则设置为-1。
//自 5.1.0 起,is_dst 参数被废弃。因此应该使用新的时区处理特性。参数总是表示 GMT 日期,因此 is_dst 对结果没有影响。
//
//参数可以从右到左依次空着,空着的参数会被设为相应的当前 GMT 值。

echo(date("M-d-Y",mktime(0,0,0,12,36,2001)));

//将输出结果如:
//
//Jan-05-2002



php获取本月、上月时间戳的方法


switch ($exchange_time) {
 
    case 1 : //本月
 
    //本月起始时间:
    $begin_time = date("Y-m-d H:i:s",mktime (0,0,0, date("m"),1,date("Y")));
    $end_time = date("Y-m-d H:i:s",mktime (23,59,59, date("m"),date("t"),date("Y")));
 
    break;
 
    case 2 : //上个月
 
    //上个月的起始时间:
    $begin_time = date('Y-m-01 00:00:00',strtotime('-1 month'));
    $end_time = date("Y-m-d 23:59:59", strtotime(-date('d').'day'));
 
    break;
 
    case 3 : //上上个月
 
    $begin_time =  date("Y-m-d H:i:s",mktime(0, 0 , 0,date("m")-2,1,date("Y")));
 
    $end_time =  date("Y-m-d H:i:s",mktime(23,59,59,date("m")-1 ,0,date("Y")));
 
    break;
 
    }
 
 
    echodate("Ymd",strtotime("now")),"
";
 
    echodate("Ymd",strtotime("-1 week Monday")),"
";
 
    echodate("Ymd",strtotime("-1 week Sunday")),"
";
 
    echodate("Ymd",strtotime("+0 week Monday")),"
";
 
    echodate("Ymd",strtotime("+0 week Sunday")),"
";
 
  
 
    echo"*********第几个月:";
 
    echodate('n');
 
    echo"*********本周周几:";
 
    echodate("w");
 
    echo"*********本月天数:";
 
    echodate("t");
 
    echo"*********";
 
  
 
    echo'<br>上周起始时间:<br>';
 
    echodate("Y-m-d H:i:s",mktime(0, 0 , 0,date("m"),date("d")-date("w")+1-7,date("Y"))),"
";
 
    echodate("Y-m-d H:i:s",mktime(23,59,59,date("m"),date("d")-date("w")+7-7,date("Y"))),"
";
 
    echo'<br>本周起始时间:<br>';
 
    echodate("Y-m-d H:i:s",mktime(0, 0 , 0,date("m"),date("d")-date("w")+1,date("Y"))),"
";
 
    echodate("Y-m-d H:i:s",mktime(23,59,59,date("m"),date("d")-date("w")+7,date("Y"))),"
";
 
  
 
    echo'<br>上月起始时间:<br>';
 
    echodate("Y-m-d H:i:s",mktime(0, 0 , 0,date("m")-1,1,date("Y"))),"
";
 
    echodate("Y-m-d H:i:s",mktime(23,59,59,date("m") ,0,date("Y"))),"
";
 
    echo'<br>本月起始时间:<br>';
 
    echodate("Y-m-d H:i:s",mktime(0, 0 , 0,date("m"),1,date("Y"))),"
";
 
    echodate("Y-m-d H:i:s",mktime(23,59,59,date("m"),date("t"),date("Y"))),"
";
 
  
 
    $season= ceil((date('n'))/3);//当月是第几季度
 
    echo'<br>本季度起始时间:<br>';
 
    echodate('Y-m-d H:i:s',mktime(0, 0, 0,$season*3-3+1,1,date('Y'))),"
";
 
    echodate('Y-m-d H:i:s',mktime(23,59,59,$season*3,date('t',mktime(0, 0 , 0,$season*3,1,date("Y"))),date('Y'))),"
";
 
  
 
    $season= ceil((date('n'))/3)-1;//上季度是第几季度
 
    echo'<br>上季度起始时间:<br>';
 
    echodate('Y-m-d H:i:s',mktime(0, 0, 0,$season*3-3+1,1,date('Y'))),"
";
 
    echodate('Y-m-d H:i:s',mktime(23,59,59,$season*3,date('t',mktime(0, 0 , 0,$seas))


本文章多为网络内容整理而来,如有侵犯您的权益,请联系我们免费删除