0

0

php怎么获得数据库数据个数组_php数据库数据转数组技巧【步骤】

雪夜

雪夜

发布时间:2025-12-14 20:34:03

|

259人浏览过

|

来源于php中文网

原创

PHP数据库查询结果转数组需根据扩展选择方法:MySQLi用mysqli_fetch_all(MYSQLI_ASSOC)或mysqli_fetch_assoc();PDO用fetchAll(PDO::FETCH_ASSOC)或fetch(PDO::FETCH_ASSOC);避免mysqli_fetch_array()默认混合键问题。

php怎么获得数据库数据个数组_php数据库数据转数组技巧【步骤】

如果您在PHP中执行数据库查询后需要将结果集转换为数组格式,则可能是由于默认的查询返回对象或资源类型,无法直接用于后续的数组操作。以下是将PHP数据库数据转换为数组的具体步骤:

一、使用mysqli_fetch_all()获取全部结果为关联数组

该方法适用于使用MySQLi面向对象或过程式风格连接数据库的场景,可一次性将查询结果所有行转为关联数组,便于遍历和处理。

1、建立MySQLi连接并执行SELECT查询语句,获取结果集对象。

2、调用mysqli_fetch_all()函数,并传入第二个参数MYSQLI_ASSOC,确保返回的是关联数组而非数字索引数组。

立即学习PHP免费学习笔记(深入)”;

3、将返回值直接赋给变量,该变量即为包含多维关联数组的结果集。

二、使用PDO的fetchALL()配合PDO::FETCH_ASSOC

当使用PDO扩展连接数据库时,可通过设置提取模式为PDO::FETCH_ASSOC,使每行结果自动以字段名为键生成关联数组,最终组合为二维数组。

1、通过PDO实例执行query()prepare()->execute()获取PDOStatement对象。

2、调用fetchAll(PDO::FETCH_ASSOC)方法,强制所有行以关联形式返回。

3、确认返回值类型为array且非空,即可安全用于foreach循环或其他数组函数。

三、逐行使用mysqli_fetch_assoc()构建数组

该方式适合内存受限环境或需对每行数据做条件过滤、格式转换等中间处理的场景,通过循环手动累积数组元素。

1、执行查询获得结果集资源。

Akkio
Akkio

Akkio 是一个无代码 AI 的全包平台,任何人都可以在几分钟内构建和部署AI

下载

2、初始化一个空数组用于存储结果。

3、使用while($row = mysqli_fetch_assoc($result))循环读取每一行。

4、在循环体内执行$data[] = $row;将当前行追加至目标数组。

四、使用PDO::FETCH_NUM与array_map组合生成索引数组

若需获取纯数字索引的一维或多维数组(如仅取某列值),可结合PDO::FETCH_NUMarray_map()进行结构转换。

1、执行查询并调用fetchAll(PDO::FETCH_NUM)获取数字索引二维数组。

2、若只需首列数据,使用array_column($rows, 0)提取第一列。

3、若需统一转换为单层索引数组,配合array_merge(...$rows)展开嵌套结构。

五、处理MySQLi结果时避免fetch_array()的默认混合键冲突

mysqli_fetch_array()默认同时返回数字索引和关联索引,易导致数组键重复或占用双倍内存;应显式指定MYSQLI_ASSOCMYSQLI_NUM参数以规避此问题。

1、检查当前使用的mysqli_fetch_array()是否未传入第二个参数。

2、将其替换为mysqli_fetch_assoc()或明确添加MYSQLI_ASSOC常量。

3、验证输出数组结构,确认无重复键名及冗余数值索引项。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1502

2023.10.24

while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

97

2023.09.25

php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

75

2025.12.04

go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

56

2025.09.05

java面向对象
java面向对象

本专题整合了java面向对象相关内容,阅读专题下面的文章了解更多详细内容。

52

2025.11.27

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1606

2023.10.23

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

358

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2082

2023.08.14

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 812人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号