我使用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"
我在试着想出最有效的方法来处理这件事。我将有可能有100s/1000的用户,每个将有大约5-10个帐户。
我尝试使用fetchAll(PDO::FETCH_GROUP|PDO::FETCH_KEY_PAIR)
,但这是不允许的。尽管手册上说它们经常一起使用?
如有任何建议,欢迎光临!
发布于 2018-07-07 04:29:01
只需使用一个简单的循环来填充适当的数组元素。
$results = array();
while ($row = $stmt->fetch(PDO::FETCH_ASSOC) {
$results[$row['user_id']][$row['account']] = $row['value'];
}
发布于 2018-07-07 04:26:29
将SQL代码重写为:
$sql = "select *
from accounts
where user_id in (select distinct user_id
from accounts)" ;
https://stackoverflow.com/questions/51216649
复制相似问题