你能解释一下为什么输出结果是这样的吗?我想知道为什么包含这个数组。我在程序中看不到任何数组字。这是怎么发生的?我怎么能只输出"1"呢?
代码:if (!$mysqli->query("DROP TABLE IF EXISTS test") ||
!$mysqli->query("CREATE TABLE test(id INT)") ||
!$mysqli->query("INSERT INTO test(id) VALUES (1)")) {
echo "Table creation failed: (" . $mysqli->errno . ") " . $mysqli->error;
}
if (!$mysqli->query("DROP PROCEDURE IF EXISTS p") ||
!$mysqli->query('CREATE PROCEDURE p() READS SQL DATA BEGIN SELECT id FROM test; SELECT id + 1 FROM test; END;')) {
echo "Stored procedure creation failed: (" . $mysqli->errno . ") " . $mysqli->error;
}
if (!$mysqli->multi_query("CALL p()")) {
echo "CALL failed: (" . $mysqli->errno . ") " . $mysqli->error;
}
do {
if ($res = $mysqli->store_result()) {
printf("---'n");
var_dump($res->fetch_all());
$res->free();
} else {
if ($mysqli->errno) {
echo "Store failed: (" . $mysqli->errno . ") " . $mysqli->error;
}
}
} while ($mysqli->more_results() && $mysqli->next_result());
?>
结果:---
array(3) {
[0]=>
array(1) {
[0]=>
string(1) "1"
}
}
我已经删除了其他输出,我只是想知道为什么数组被包括在内。
mysqli的fetch_all返回一个数组。从http://www.php.net/manual/en/mysqli-result.fetch-all.php的文档中可以看到,返回值是"返回保存结果行的关联数组或数字数组数组"。你得到一个数组。你所拥有的是1行(作为一个数组)和1值(在一个数组中),值为"1"。
注意,根据文档- mysqli_result::fetch_all
的返回类型
http://php.net/manual/en/mysqli-result.fetch-all.php refsect1-mysqli-result.fetch-all-returnvalues