erdalceylan / array-join
Array join
2.1.0
2020-01-08 07:13 UTC
Requires
- php: >=7.0
This package is auto-updated.
Last update: 2025-01-08 18:16:15 UTC
README
Installation
Using Composer
composer require erdalceylan/array-join
OR
composer.json
{ "require": { "erdalceylan/array-join": "dev-master" } }
USAGE
data
$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"], ];
example 1
$instance = \ArrayJoin\Builder::newInstance() ->select("a.nick") ->from($users, "a") ->setFetchType(\ArrayJoin\Builder::FETCH_TYPE_ARRAY); $instance->execute(); //output array ( array ('nick' => 'erdal'), array ('nick' => 'furkan'), array ('nick' => 'huseyin'), array ('nick' => 'hümeyra'), array ('nick' => 'tuba',) );
example 2
$instance = \ArrayJoin\Builder::newInstance() ->select("a.id", "a.nick", "b.item") ->from($users, "a") ->innerJoin($items, "b", new \ArrayJoin\On("a.id = b.user_id")) ->setFetchType(\ArrayJoin\Builder::FETCH_TYPE_ARRAY) ->offset(1) ->limit(2); $instance->execute(); //output array ( array ('id' => 1,'nick' => 'erdal','item' => 'çorap',), array ('id' => 1,'nick' => 'erdal','item' => 'çorap',) );
example 3
$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(function ($id, $text, $item, $food){ return $id < 50; }, "a.id", "c.text", "b.item", "d.food") ->groupBy("a.id", "d.food") ->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', )), );