一、查询结果
在php中,使用mysqli或pdo连接数据库进行查询操作。以下是使用mysqli查询的示例代码:
$mysqli = new mysqli(localhost, user, password, database);$sql = select name, age from users;$result = $mysqli->query($sql);
使用pdo的示例代码:
$pdo = new pdo(mysql:host=localhost;dbname=database, user, password);$sql = select name, age from users;$result = $pdo->query($sql);
无论是mysqli还是pdo,执行查询语句后,都会返回一个结果集对象。
二、将结果转换为数组
将查询结果转换为数组有两种方法,一种是使用mysqli或pdo自带的fetch函数,一行一行地转换;另一种是一次性将整个结果集取出到数组中。
fetch()方法fetch方法用于从结果集中取出一行数据,并将指针向下移动一行。可以循环调用fetch()方法以获取整个结果集。以下是示例代码:
// mysqli示例代码$rows = array();while ($row = $result->fetch_assoc()) { $rows[] = $row;}// pdo示例代码$rows = array();while ($row = $result->fetch(pdo::fetch_assoc)) { $rows[] = $row;}
以上代码使用fetch_assoc()或fetch_assoc取出的是关联数组,也可以使用fetch_array()或fetch_both获取包含数字和关联键的数组,fetch_object()或fetch_obj返回对象。
fetch_all()方法fetch_all()方法是将整个结果集一次性取出到数组中。fetch_all()是pdo中的函数,mysqli中需要使用get_result()获取结果集对象。以下是示例代码:
// mysqli示例代码$rows = $result->get_result()->fetch_all(mysqli_assoc);// pdo示例代码$rows = $result->fetch_all(pdo::fetch_assoc);
以上代码将结果集一次性取出,并将结果集的所有数据以关联数组的形式存储在一个二维数组中。
三、总结
以上介绍的两种方法各有优缺点,使用fetch()方法可以逐行处理结果,更加灵活,但需要大量的代码来处理每一行数据。而fetch_all()方法可以一次性将整个结果取出,代码简单,但是当数据量过大时,可能会占用过多的内存。
在实际开发中,可以根据实际情况选择适合的方法。如果查询结果集较小,可以使用fetch()方法;否则,建议使用fetch_all()方法。
以上就是php将查询结果弄成二维数组的详细内容。
