Создание объектов внутри объектов из MySQL SELECT

0

Я делаю базовый SELECT, как это, используя 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) но это запрещено. Хотя в руководстве говорится, что они часто используются вместе?

Любые предложения приветствуются!

  • 0
    stackoverflow.com/questions/16846531/… . Я бы использовал это, а затем создать новый массив в нужной вам настройке
  • 0
    Я думаю, что вы хотите PDO::FETCH_COLUMN|PDO::FETCH_GROUP
Показать ещё 5 комментариев
Теги:
arrays
pdo

2 ответа

0
Лучший ответ

Просто используйте простой цикл, который заполняет соответствующие элементы массива.

$results = array();
while ($row = $stmt->fetch(PDO::FETCH_ASSOC) {
    $results[$row['user_id']][$row['account']] = $row['value'];
}
  • 0
    Это обеспечивает результат в том же формате?
  • 0
    Я уверен, что это так.
Показать ещё 3 комментария
-2

Перезапишите код SQL как: -

$sql = "select *
        from accounts
        where user_id in (select distinct user_id
                          from accounts)" ;
  • 0
    Это WHERE не имеет значения.
  • 0
    Как строка может не соответствовать этому условию?

Ещё вопросы

Сообщество Overcoder
Наверх
Меню