php - 从 MySQL SELECT 的对象中创建对象
问题描述
我正在使用 PHP 和 PDO 进行这样的基本 SELECT:
SELECT user_id, account, value FROM accounts;
我得到这样的东西:
+---------+---------+-------+
| USER ID | ACCOUNT | VALUE |
+---------+---------+-------+
| 12 | abc | 12.00 |
| 12 | def | 98.00 |
| 21 | ghi | 25.00 |
| 32 | qwe | 32.00 |
+---------+---------+-------+
我希望它以这种格式保存到数组/对象中:
[12] => Array
(
[abc] => "12.00"
[def] => "98.00"
)
[21] => Array
(
[ghi] => "25.00"
)
[32] => Array
(
[qwe] => "32.00"
)
这样我以后可以做这样的事情:
$myArray['12']['def'] // "98.00"
我试图想出最有效的方法来处理这个问题。我将有可能拥有 100 或 1000 名用户,每个用户将拥有大约 5-10 个帐户。
我尝试使用fetchAll(PDO::FETCH_GROUP|PDO::FETCH_KEY_PAIR)
,但这是不允许的。虽然手册上说它们经常一起使用?
任何建议表示赞赏!
解决方案
只需使用一个简单的循环来填充适当的数组元素。
$results = array();
while ($row = $stmt->fetch(PDO::FETCH_ASSOC) {
$results[$row['user_id']][$row['account']] = $row['value'];
}
推荐阅读
- python - PyCharm 编辑器和 Python 控制台未解决的参考
- pandas - 在混合数据框中将真/假转换为 0/1 布尔值
- powershell - 我的 windows 7 机器上的 powershell 配置文件的位置不一致
- spring-boot - 如何在freemarker中将复选框绑定到dto
- c# - 意图重定向漏洞
- javascript - 如何在 eslintrc 文件中使用 import?
- css - 如何在媒体查询中使用两个纵横比?
- asp.net-core - .NET Core SignalR 客户端未连接到 ASP.NET Core 集线器
- sql - 选择查询以根据列值检索单行多值
- php - 当表中的 tr 为空时更改颜色