从MySQL SELECT在对象内创建对象

时间:2018-07-06 19:30:55

标签: php mysql arrays pdo

我正在使用PHP和PDO做这样的基本选择:

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),但这是不允许的。尽管手册说它们经常一起使用?

任何建议都值得赞赏!

2 个答案:

答案 0 :(得分:0)

只需使用填充适当数组元素的简单循环即可。

$results = array();
while ($row = $stmt->fetch(PDO::FETCH_ASSOC) {
    $results[$row['user_id']][$row['account']] = $row['value'];
}

答案 1 :(得分:-1)

将SQL代码重新写入为:-

$sql = "select *
        from accounts
        where user_id in (select distinct user_id
                          from accounts)" ;