Intereting Posts
Как запустить банку с веб-сервера с помощью PHP ZF2: Как подключить специальный слушатель модуля для отправки. Поиск ссылок, соответствующих заданной строке в запросе xpath / domdocument удаление строки в таблице с кнопкой удаления в php Laravel и Dropbox WebAuth: «Отсутствует токен CSRF в сеансе» MongoDB: кросс-сборные запросы Игнорировать чувствительность к регистру при сравнении строк в PHP Как создать файл с помощью функции PHP fopen () с кодировкой UTF 16? Ручное создание ассоциативного массива Использование JQgrid и sortableRows. Обновить порядок строк в таблице Regex: сопоставить html-тег только в том случае, если он содержит определенный идентификатор класса Лак: как отдельно кешировать страницы на основе значения определенного файла cookie Является ли Markdown (с strip_tags) достаточным для остановки атак XSS? Проблема с базой данных Laravel 5 отключить трассировку стека PHP

Присоединить многомерный массив, такой как SQL

У меня есть следующий массив. parentId важно!

 Array ( [0] => Array ( [id] => 1 [name] => Home [parentId] => [children] => ) [1] => Array ( [id] => 2 [name] => About [parentId] => [children] => ) [2] => Array ( [id] => 3 [name] => Services [parentId] => 2 [children] => ) ) 

И ниже мой expected результат массива. Вы увидите, что Services находятся в разделе « About , у которых есть идентификатор 2 а службы parentId – 2

 Array ( [0] => Array ( [id] => 1 [name] => Home [parentId] => [children] => ) [1] => Array ( [id] => 2 [name] => About [parentId] => [children] => Array ( [0] => Array ( [id] => 3 [name] => Services [parentId] => 2 [children] => ) ) ) ) 

Я могу сделать это с помощью array_walk или array_map и легко array_walk array_map foreach .

Я просто удивляюсь, есть ли какая-либо function которая объединяет индексы массива, такие как SQL JOIN без foreach loop ?

Итак, в моем массиве: id = parentId

попробуйте эту библиотеку

https://github.com/erdalceylan/array-join

ДАННЫЕ

 $users = [ ["id"=>1, "nick"=>"erdal"], (object)["id"=>2, "nick"=>"furkan" ], ["id"=>3, "nick"=>"huseyin"], ["id"=>4, "nick"=>"hümeyra" ], ["id"=>5, "nick"=>"tuba" ], ]; $items = [ ["user_id"=>1, "item"=>"kaban", "mmx" => "mmx1"], ["user_id"=>1, "item"=>"çorap", "mmx" => "mmx2"], ["user_id"=>1, "item"=>"çorap", "mmx" => "mmx3"], (object)["user_id"=>1, "item"=>"çorap", "mmx" => "mmx4"], ["user_id"=>1, "item"=>"çorap", "mmx" => "mmx5"], ["user_id"=>1, "item"=>"çorap", "mmx" => "mmx6"], ["user_id"=>2, "item"=>"araba", "mmx" => "mmx7"], (object)["user_id"=>9, "item"=>"ev", "mmx" => "mmx8"], ["user_id"=>10, "item"=>"yat", "mmx" => "mmx9"], ]; $foods = [ ["user_id"=>1, "food"=>"iskender"], ["user_id"=>2, "food"=>"adana"], ]; $texts = [ ["user_id"=>1, "text"=>"merhaba"], ["user_id"=>15, "text"=>" hi"], ]; 

ПРИМЕНЕНИЕ

 $instance = \ArrayJoin\Builder::newInstance() ->select("a.id", "a.nick", "b.item", "d.food") ->from($users, "a") ->innerJoin($items, "b", new \ArrayJoin\On("a.id = b.user_id")) ->leftJoin($texts, "c", new \ArrayJoin\On("a.id = c.user_id")) ->rightJoin($foods, "d", new \ArrayJoin\On("b.user_id = d.user_id")) ->where("a.id", "a.text", function ($fieldFirs, $fieldSecond){ return $fieldFirs < 10; }) ->limit(2) ->offset(1) ->setFetchType(\ArrayJoin\Builder::FETCH_TYPE_OBJECT); $instance->execute(); 

ВЫВОД

  array ( stdClass::__set_state(array( 'id' => 1, 'nick' => 'erdal', 'item' => 'çorap', 'food' => 'iskender', )), stdClass::__set_state(array( 'id' => 1, 'nick' => 'erdal', 'item' => 'çorap', 'food' => 'iskender', )), ) 

массива массива, как это делается на изображениях.

  [1][children][0] => Array ( [id] => 3 [name] => Services [parentId] => 2 [children] => ) 

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