我需要从 2 个不同的查询中获取数据。我想将它们存储为 2 个单独的变量。
首先我尝试了这个:
// 1. Create a database connection
$mysqli = new mysqli(DB_SERVER, DB_USER, DB_PASS, DB_NAME, DB_PORT);
if ($mysqli->connect_errno) {
echo "No connection" ;
}
// 2. first query
$query = "CALL sp1('2015-01-01', '2015-01-31');";
$result = $mysqli->query($query);
$var1 = array();
while($shop = $result->fetch_object()) {
$var1[] = $shop;
}
echo '<pre>', print_r($var1), '</pre>';
$result->free();
// 3. second query
$query = "CALL sp2('2015-01-01', '2015-01-31');";
$result = $mysqli->query($query);
$var2 = array();
while($shop = $result->fetch_object()) {
$var2[] = $shop;
}
echo '<pre>', print_r($var2), '</pre>';
我从第一个查询中获取数据,但是当 php 尝试获取第二个查询时,我收到了这个错误:
致命错误:在布尔值上调用成员函数 fetch_object()
我阅读了有关 multi_query 的信息,但找不到任何有关将查询的输出保存为单独变量的信息。
附加信息:即使我切换查询总是第二个不正确。我不知道如何加载第二个查询以及前一个查询发生了什么(在我写时被删除:result->free?)