在While循环中建立索引的PHP数组

时间:2019-07-29 15:38:46

标签: php mysql arrays indexing

我正在尝试将自己的数据(当前仅显示在各种表和KPI指标块中)格式化为图形框架所需的格式。本质上,我希望我的一些值成为图形生成脚本的X和Y数据。

这是理想的结果(一个可以从中生成图形/图形点的数组的示例):

$dataPoints = array(
        array("x"=> 1, "y"=> 41, label=> "18/07/19"),
        array("x"=> 2, "y"=> 35, label=> "19/07/19"),
        array("x"=> 3, "y"=> 50, label=> "20/07/19"),
        array("x"=> 4, "y"=> 45, label=> "21/07/19"),
        array("x"=> 5, "y"=> 52, label=> "22/07/19"),
        array("x"=> 6, "y"=> 68, label=> "23/07/19")
);

我有以下代码可提取所需的相关信息:

//Build Graph Data Points
//
$daysmax=31;
$daycounter=0;
while($daysmax > $daycounter) {
  $sql_get_day_total_events="SELECT COUNT(*),date_sub(curdate(),INTERVAL $daycounter day) as date1 FROM tblticketlog
    WHERE DATE(date) = date_sub(curdate(),INTERVAL $daycounter day)
    AND ((action = 'New Support Ticket Opened')
    OR (action LIKE 'Status changed to Pending%')
    OR (action LIKE 'Status changed to In Progress%')
    OR (action LIKE 'New Ticket Response made by%'))";
  $get_day_total_events_result=mysqli_query($db,$sql_get_day_total_events);
  if(mysqli_num_rows($get_day_total_events_result) > 0) {
    while($row = $get_day_total_events_result->fetch_assoc()) {
      $day_result_date=strtotime($row['date1']);
      $day_result_value=$row['COUNT(*)'];
    }
  }
  $sql_get_day_escs="SELECT COUNT(*) FROM escalations
    WHERE DATE(esc_at) = date_sub(curdate(), INTERVAL $daycounter day)
    AND escalated = 1";
  $get_day_escs_result=mysqli_query($db2,$sql_get_day_escs);
  if(mysqli_num_rows($get_day_escs_result) > 0) {
    while($row = $get_day_escs_result->fetch_assoc()) {
      $day_escs_value=$row['COUNT(*)'];
    }
  }
  $day_slas_met = $day_result_value - $day_escs_value;
  $day_kpi_pcnt = round((($day_slas_met / $day_result_value) * 100),0);
  $daycounter=$daycounter + 1;
}

总而言之,我从$ db中提取了30天(滚动)中每天的总事件,从$ db2中提取了30天(滚动)中每天“升级事件”的数量。而且我也从$ db查询中获取日期。

对于我的图表:
X = $ daycounter(只是数据点的增量数字ID,从0开始到30
Y = KPI百分比,它是使用$ day_kpi_pcnt
中的简单数学计算得出的 LABEL =纯文本格式的日期对象

我试图做的事
我在循环之前用以下方法初始化了$ datapoints数组:

$datapoints = array();

然后,在循环底部的$ daycounter + 1行之前,我尝试将值推入数组中的索引:

$datapoints[x] = $daycounter;
$datapoints[label] = date("d-m-Y",$day_result_date);
$datapoints[y] = $day_kpi_pcnt;

但是,最后只是一个空图。如果我var_dump数组,我似乎将结果的最后一行放在否则为空的数组中:

**Day: 30 -- 29-06-2019 - 6/6 - 100%**
array(3) { ["x"]=> int(30) ["label"]=> string(10) "29-06-2019" ["y"]=> float(100) } 

老实说,PHP数组以及如何使用它们可能是我最薄弱的话题。我真的很努力地与他们抗争,并希望得到一些有关我犯错地方的指导甚至一些基本技巧。谢谢。

2 个答案:

答案 0 :(得分:5)

您所做的可能是这样的:

$datapoints = [];
while (...) {
    ...
    $datapoints[x] = $daycounter;
    $datapoints[label] = date("d-m-Y",$day_result_date);
    $datapoints[y] = $day_kpi_pcnt;
    ...
}

您将在每次循环迭代中用新的行值覆盖$datapoints数组。因此,仅保留来自最后一行的值。相反,您需要将行附加到数组:

$datapoints = [];
while (...) {
    ...
    $datapoints[] = [
        'x' => $daycounter,
        'label' => date("d-m-Y",$day_result_date),
        'y' => $day_kpi_pcnt,
    ];
    ...
}

答案 1 :(得分:1)

您需要一个数组数组。首先,为所有结果创建一个数组(您已经拥有了),并创建一个临时数组(这在循环之外)。

$datapoints = $temp_datapoint = array();

然后像您一样,使用数据创建一个临时数组(这在循环内):

$temp_datapoint['x'] = $daycounter;
$temp_datapoint['label'] = date("d-m-Y",$day_result_date);
$temp_datapoint['y'] = $day_kpi_pcnt;

然后将整个数组附加到循环内的datapoints数组中:

$datapoints[] = $temp_datapoint;