Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sql-server/26.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添加另一个数组_Php_Arrays_Highcharts_Drilldown - Fatal编程技术网

PHP添加另一个数组

PHP添加另一个数组,php,arrays,highcharts,drilldown,Php,Arrays,Highcharts,Drilldown,我试图用从数据库检索到的动态值呈现Highcharts列 我有一个php查询,如下所示: $query = mssql_query("SELECT count(create_at) as create, month(create_at) as month, year(create_at) as year FROM tblCrew WHERE create_at >= '01 JUL 2011' AND create_at

我试图用从数据库检索到的动态值呈现Highcharts列

我有一个php查询,如下所示:

$query = mssql_query("SELECT count(create_at) as create,  month(create_at) as month, year(create_at) as year
                FROM tblCrew 
                WHERE create_at >=  '01 JUL 2011' AND create_at <=  '31 JUL 2013'
                GROUP BY  month(create_at), year(create_at) 
                ORDER BY  year(create_at) ASC, month(create_at) ASC ");
while ($data = mssql_fetch_array($query))
            {
                if (!isset($case[$data['year']])) {
                                $case[$data['year']] = array(
                                    'name' => $data['year'],
                                    'data' => array()
                                );
                    }

                    $case[$data['year']]['data'][] = array(
                        $data['month'],
                        $data['create']
                    );

            }
结果如下:

$case = Array([2011] => Array
    (
        [name] => 2011
        [data] => Array
            (
                [0] => Array ( [0] => JUL [1] => 166 )
                [1] => Array ( [0] => AUG [1] => 144 )
                ........
                .......
                [5] => Array ( [0] => DEC [1] => 124 )
            )
    )

[2012] => Array
    (
        [name] => 2012
        [data] => Array
            (
                [0] => Array ( [0] => JAN [1] => 143 )
                [1] => Array ( [0] => FEB [1] => 177 )
                ........
                .......
                [5] => Array ( [0] => DEC [1] => 132 )
            )
    )       

[2013] => Array
    (
        [name] => 2013
        [data] => Array
            (
                [0] => Array ( [0] => JAN [1] => 166 )
                ........
                .......
                [5] => Array ( [0] => JUL [1] => 124 )
            )
    )       
)

现在我正在尝试添加另一个数组,我将对每年的数据进行汇总,并将其放入另一个数组中。就像下面的例子

$total[] = Array[{name: '2011', total: '1520'}, {name: '2012', total: '2241'}, {name: '2013', total: '1864'}]   

您可以添加另一个数组,在初始化
$case[$data['year']]]
的同时初始化它,并在循环结果时添加值:

$total = array();
while ($data = mssql_fetch_array($query))
        {
            if (!isset($case[$data['year']])) {
                            $case[$data['year']] = array(
                                'name' => $data['year'],
                                'data' => array()
                            );
                            $total[$data['year']] = array(
                                'name' => $data['year'],
                                'total' => 0
                            );
                }

                $case[$data['year']]['data'][] = array(
                    $data['month'],
                    $data['create']
                );
                $total[$data['year']]['total'] += $data['create'];

        }
print_r($total);