Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/72.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 如何使用SUMIF或任何sql查询来聚合调查数据的结果?_Php_Mysql_Sql_Laravel_Laravel 5.4 - Fatal编程技术网

Php 如何使用SUMIF或任何sql查询来聚合调查数据的结果?

Php 如何使用SUMIF或任何sql查询来聚合调查数据的结果?,php,mysql,sql,laravel,laravel-5.4,Php,Mysql,Sql,Laravel,Laravel 5.4,我这里有一个在仪表板中使用的查询,用于对调查响应进行排序。我想让我的查询添加ff ie的结果 'Male - In Love' + 'Female - In Love'; 'Male - Like' + 'Female - Like'; 'Male - Facepalm' + 'Female - Facepalm'; 'Male - Crying' + 'Female - Crying'; 以下是我用来对单个响应进行排序的查询: 顺便说一句,我使用的是Laravel5.4和mysql p

我这里有一个在仪表板中使用的查询,用于对调查响应进行排序。我想让我的查询添加ff ie的结果

'Male - In Love' + 'Female - In Love'; 
'Male - Like' + 'Female - Like'; 
'Male - Facepalm' + 'Female - Facepalm'; 
'Male - Crying' + 'Female - Crying';
以下是我用来对单个响应进行排序的查询:

顺便说一句,我使用的是Laravel5.4和mysql

public function getDataTwo(Request $request){
    $data = DB::connection('mysql')->select(DB::raw("SELECT 
        DATE(`created_at`) as 'DATE',
        SUM(IF(`responses`=1,1,0)) as 'Male - In Love',
        SUM(IF(`responses`=2,1,0)) as 'Male - Like',
        SUM(IF(`responses`=3,1,0)) as 'Male - Facepalm',
        SUM(IF(`responses`=4,1,0)) as 'Male - Crying',
        SUM(IF(`responses`=5,1,0)) as 'Female - In Love',
        SUM(IF(`responses`=6,1,0)) as 'Female - Like',
        SUM(IF(`responses`=7,1,0)) as 'Female - Facepalm',
        SUM(IF(`responses`=8,1,0)) as 'Female - Crying'
        FROM `answers` 
        WHERE DATE(`created_at`) BETWEEN DATE('$request->startDate') AND
        DATE('$request->endDate')                             
        AND TIME(`created_at`) BETWEEN TIME('$request->startDate') AND 
        TIME('$request->endDate')
        -- AND driverid = ('*')
        -- AND busid = ('*')
        -- AND routeid = ('*')
        -- AND questionid = ('*') 
        GROUP BY DATE(`created_at`)"
    )); //Array and Result nito
    $tempArr = array();
    if(count($data)==0){return $data;}
    $xcnt=0;
    foreach ($data[0] as $key => $value) {
        if($key=='DATE'){continue;}
        $tempArr[$xcnt]=array("name"=>$key,"y"=>(int)$value);
        $xcnt++;
    }
    $data = json_encode($tempArr);
    return $data;
}

您正在使用MySQL,因此可以使用以下快捷方式更轻松地编写查询:

SELECT DATE(created_at) as DATE,
       SUM(responses = 1) as `Male - In Love`,
       SUM(responses = 2) as `Male - Like`,
       SUM(responses = 3) as `Male - Facepalm`,
       SUM(responses = 4) as `Male - Crying`,
       SUM(responses = 5) as `Female - In Love`,
       SUM(responses = 6) as `Female - Like`,
       SUM(responses = 7) as `Female - Facepalm`,
       SUM(responses = 8) as `Female - Crying`
FROM answers 
. . .
然后,您可以轻松添加更多列,如下所示:

SELECT DATE(created_at) as DATE,
       SUM(responses = 1) as `Male - In Love`,
       SUM(responses = 2) as `Male - Like`,
       SUM(responses = 3) as `Male - Facepalm`,
       SUM(responses = 4) as `Male - Crying`,
       SUM(responses = 5) as `Female - In Love`,
       SUM(responses = 6) as `Female - Like`,
       SUM(responses = 7) as `Female - Facepalm`,
       SUM(responses = 8) as `Female - Crying`,
       SUM(responses IN (1, 5)) as `Males + Females - In Love`),
       . . . 
FROM answers 
. . .
注:

  • IF()
    已经是非标准SQL。您还可以使用MySQL更方便的“将布尔值视为数字”扩展
  • 仅对字符串和日期常量使用单引号。不要将它们用作列别名

实际发生了什么?你期望发生什么?寻求调试帮助的问题(“为什么这段代码不起作用?”)必须包括所需的行为、特定的问题或错误以及在问题本身中重现它所需的最短代码。没有明确问题陈述的问题对其他读者没有用处。见: