0

我正在尝试使用 php 和 ajax 显示数据以引导数据表(4 列)mysqli_multi_query()

我无法让第二个查询使用UNIONor INNER JOIN。我不是程序员,几乎可以得到正确的结果,但由于某种原因,第一个查询返回“null”值。

我该如何改变呢?

这是一个日志示例和我的代码:

PHP 通知:未定义的偏移量:第 26 行上的 2 PHP 通知:未定义的偏移量:第 27 行上的 3 {"sEcho":1,"iTotalRecords":1,"iTotalDisplayRecords":1,"aaData":{"CommonInverterData":[{ “日期”:null,“生成”:null,“导出”:“0.9921563111569116”,“导入”:“1.8864974578334937”}

/* Database connection start */ 
include ('db.php');

$conn = mysqli_connect($hn, $un, $pw, $db) or die("Connection failed: " . mysqli_connect_error());

/* Database connection end */

$sql = "SELECT m.`date`, `day_energy`
        FROM `CommonInverterData`
        JOIN ( SELECT `date`, MAX(`time`) 'maxtime'
        FROM `CommonInverterData`
        GROUP BY `date`) m
        ON m.maxtime = `CommonInverterData`.`time`
        AND m.`date` = `CommonInverterData`.`date`;";

$sql .= "SELECT ABS(SUM((CASE WHEN `P_Grid`<0 THEN `P_Grid` ELSE 0 END) / 60000 )) as 'Export', SUM((CASE WHEN `P_Grid`>=0 THEN `P_Grid` ELSE 0 END) / 60000 ) as 'Import' FROM `PowerFlowRealtimeData` GROUP BY `date`;";

if (mysqli_multi_query($conn, $sql) or die(mysqli_error($conn))) {
    do {
        if ($result=mysqli_store_result($conn)) {
            $data = array();
            while( $rows = mysqli_fetch_row($result) ) {
                $data[] = array(
                    'Date' => $rows[2],
                    'Generated' => $rows[3],
                    'Export' => $rows[0],
                    'Import' => $rows[1],
                );
            } mysqli_free_result($result);
        }
    } while (mysqli_next_result($conn));
}
mysqli_close($conn);

$return = array(
    "sEcho" => 1,
    "iTotalRecords" => count($data),
    "iTotalDisplayRecords" => count($data),
    "aaData"=>$data);

echo json_encode($return);
4

2 回答 2

1

不要乱用 mysqli_multi_query()。

运行一个查询,将结果收集到数组中。
运行另一个查询,将结果收集到数组中。
将结果组合在一个简单的循环中。
问题解决了。提供最简单的工具。

而最明智的解决方案是使用实际的 JOIN。对于whish,您应该一直在问一个SQL问题。

于 2017-08-11T04:57:56.443 回答
0
  1. 您没有检查mysqli_more_results().

  2. 您尝试访问每个结果集中的 4 个元素,尽管每个查询只提供了两个元素。

我已将您的代码段与我不久前构建的通用代码块混合在一起,以帮助人们理解和调试mysqli_multi_query(). 如果实施后仍然有问题,此代码块应该可以帮助您找出原因。

$sql=["SELECT m.`date`, `day_energy`
        FROM `CommonInverterData`
        JOIN ( SELECT `date`, MAX(`time`) 'maxtime'
        FROM `CommonInverterData`
        GROUP BY `date`) m
        ON m.maxtime = `CommonInverterData`.`time`
        AND m.`date` = `CommonInverterData`.`date`",
      "SELECT ABS(SUM((CASE WHEN `P_Grid`<0 THEN `P_Grid` ELSE 0 END) / 60000 )) as 'Export',
        SUM((CASE WHEN `P_Grid`>=0 THEN `P_Grid` ELSE 0 END) / 60000 ) as 'Import'
        FROM `PowerFlowRealtimeData` GROUP BY `date`"
    ];

if(mysqli_multi_query($conn,implode(';',$sql))){
    do{
        // echo "<br><br>",key($sql),": ",current($sql);  // display key:value @ pointer
        if($result=mysqli_store_result($conn)){   // if a result set
            while($rows=mysqli_fetch_row($result)){
                // echo "<br>Cols: {$rows[0]}, {$rows[1]}";
                if(key($sql)===0){  (first query)
                    $tmp1[]=['Date'=>$rows[0],'Generated'=>$rows[1]];
                }else{  // key($sql)===1 (second query)
                    $tmp2[]=['Export'=>$rows[0],'Import'=>$rows[1]];
                }
            }
            mysqli_free_result($result);
        }
        // echo "<br>Rows = ",mysqli_affected_rows($conn); // acts like num_rows on SELECTs
    } while(next($sql) && mysqli_more_results($conn) && mysqli_next_result($conn));
}
if($mysqli_error=mysqli_error($conn)){
    echo "<br><br>",key($sql),": ",current($sql),"Syntax Error:<br>$mysqli_error";  // display array pointer key:value
}
mysqli_close($conn);

$data=array_replace_recursive($tmp1,$tmp2);  // blend the temporary arrays together
$return = array(
    "sEcho" => 1,
    "iTotalRecords" => count($data),
    "iTotalDisplayRecords" => count($data),
    "aaData"=>$data);

echo json_encode($return);

事实是:mysqli_multi_query()不是这种情况的最佳实践。如果这是我的任务/项目,我会尝试将查询合并到一个调用中(并避免mysqli_multi_query()完全调用)。

这是我建议使用 UNION 查询可以做什么的链接: https ://stackoverflow.com/a/34758622/2943403 如果您走这条路,请记住您仍将每行生成 2 列(不是 4列)。

正如 YourCommonSense 建议JOIN的那样,这将是最佳实践,因为您将能够每行生成 4 列并简化结果集处理。重复 YCS,这值得提出一个新问题,其中包含有关您的数据库表和所需输出的单独/附加详细信息。如果您想收到有关如何编写查询的高质量响应,请务必包含所有涉及的表的 sqlfiddle 并解释表关系。

于 2017-08-11T04:17:49.360 回答