php是一种常用的编程语言,常用于开发Web应用程序。查询数据库是php中常用的操作之一,查询结果需要以数组的形式返回。本文将介绍如何将查询结果转换为二维数组。
一、查询结果
在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()方法以获取整个结果集。以下是示例代码:
// 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()是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将查询结果弄成二维数组的详细内容。更多信息请关注PHP中文网其他相关文章!