CodeIgniter присоединяется из той же таблицы [дубликат]Php

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 CodeIgniter присоединяется из той же таблицы [дубликат]

Сообщение Anonymous »

У меня есть одна таблица под названием «гости».

Гость может быть гостевым или plus_one.

Если это plus_one, этот plus_one связан с гостем посредством master_id. Идентификатор столбца увеличивается автоматически.

Таблица

id master_id type
1 1 guest
2 1 plus_one
3 3 guest
4 3 plus_one
5 5 guest
6 6 guest


Ожидаемый результат запроса — это массив с массивом для каждого гостя, и если у этого гостя есть плюс_один, прикрепленный через master_id, он имеет это как дополнительный массив.

Если принять во внимание приведенную выше таблицу, это должно выглядеть так (упрощенно):

[0]
['id'] => 1
['master_id'] => 1
['type'] => guest
['plus_one'] => // This is a sub array
['id'] => 2
['master_id'] => 1
[1]
['id'] => 3
['master_id'] => 3
['type'] => guest
['plus_one'] => // This is a sub array
['id'] => 4
['master_id'] => 3
[2]
['id'] => 5
['master_id'] => 5
['type'] => guest
[3]
['id'] => 6
['master_id'] => 6
['type'] => guest


Я думаю, мне нужно выполнить самостоятельное соединение, но я не могу понять, как это сделать, а также не могу понять, как в результате получить подмассив. Что я пробовал:

$this->db->from('guests a');

$this->db->join('guests b', 'a.master_id = b.master_id', 'left outer');

$query = $this->db->get();
return $query->result_array();


Подробнее здесь: https://stackoverflow.com/questions/475 ... same-table
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»