首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >通过MySQL SELECT在对象内创建对象

通过MySQL SELECT在对象内创建对象
EN

Stack Overflow用户
提问于 2018-07-07 03:30:55
回答 2查看 43关注 0票数 0

我使用PHP和PDO做一个基本的SELECT操作:

代码语言:javascript
复制
SELECT user_id, account, value FROM accounts;

我得到的东西是这样的:

代码语言:javascript
复制
+---------+---------+-------+
| USER ID | ACCOUNT | VALUE |
+---------+---------+-------+
| 12      | abc     | 12.00 |
| 12      | def     | 98.00 |
| 21      | ghi     | 25.00 |
| 32      | qwe     | 32.00 |
+---------+---------+-------+

我希望将其保存到以下格式的数组/对象中:

代码语言:javascript
复制
[12] => Array
    (
       [abc] => "12.00"
       [def] => "98.00"
    )
[21] => Array
    (
       [ghi] => "25.00"
    )
[32] => Array
    (
       [qwe] => "32.00"
    )

这样我以后就可以做这样的事情了:

代码语言:javascript
复制
$myArray['12']['def'] // "98.00"

我在试着想出最有效的方法来处理这件事。我将有可能有100s/1000的用户,每个将有大约5-10个帐户。

我尝试使用fetchAll(PDO::FETCH_GROUP|PDO::FETCH_KEY_PAIR),但这是不允许的。尽管手册上说它们经常一起使用?

如有任何建议,欢迎光临!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-07-07 04:29:01

只需使用一个简单的循环来填充适当的数组元素。

代码语言:javascript
复制
$results = array();
while ($row = $stmt->fetch(PDO::FETCH_ASSOC) {
    $results[$row['user_id']][$row['account']] = $row['value'];
}
票数 0
EN

Stack Overflow用户

发布于 2018-07-07 04:26:29

将SQL代码重写为:

代码语言:javascript
复制
$sql = "select *
        from accounts
        where user_id in (select distinct user_id
                          from accounts)" ;
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51216649

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档