我用 PDO 编写了一个 SQL 查询。 DB 表有 3 个与查询匹配的结果。但 PDO 仅显示一项结果。
我的代码是这样的
conn.php
function connect() {
$servername = "localhost";
$dbname = "guiding_db";
$username = "user";
$password = "pass";
$conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
return $conn;
}
_admin.php
include_once './conn.php';
function getStudentsRequests(){
$sql = "SELECT * FROM `user` WHERE signas = 'student' AND accept='0'";
$result = connect()->query($sql);
$out = $result->fetch(PDO::FETCH_ASSOC);
print_r($out);
return $out;
}
getStudentsRequests();
最佳答案
PDOStatement::fetch()
仅加载单行。使用PDOStatement::fetchAll()
加载所有行(或使用 while
循环):
$out = $result->fetchAll(PDO::FETCH_ASSOC);
关于PHP PDO 总是只给出一个结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37857943/