dongyang7152 2014-07-08 09:25
浏览 55
已采纳

PHP添加另一个数组

I'm trying to render a Highcharts column drilldown with dynamic values retrieved from database.

And I have a php query like this:

$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 ");

And to get the result I looped it like this:

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']
                    );

            }

And this is the results:

$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 )
            )
    )       

)

And now I am trying to add another array where I will sum up the data per year and put it in another array. Like the example below.

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

1条回答 默认 最新

  • doulezhi5326 2014-07-08 09:49
    关注

    You can add another array, initialize it the same time you initialize $case[$data['year']] and add values while looping the results :

    $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);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 2024-五一综合模拟赛
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭