I have a problem with Laravel 4 query builder, i want make a re-usable method
public function getData($where=array())
{
// $where = array(\'city\' =>
$where[] = array(
'field' => 'city',
'operator' => '=',
'value' => 'jakarta'
);
$where[] = array(
'field' => 'age',
'operator' => '=',
'value' => 25
);
$data = getData($where);
public function getData($wheres = array()){
$query = User::query();
if(!empty($wheres)){
foreach($wheres as $where){
{
$query = $query->where($where['field'], $where['operator'], $where['value']);
}
$result = $query->get();
}
}
You may try this (Assumed, this function is in your User
model)
class User extends Eloquent {
public static function getData($where = null)
{
$query = DB::table('User');
if(!is_null($where )) {
foreach($where as $k => $v){
$query->where($k, $v);
}
}
return $query->get();
}
}
Rember that, =
is optional. Call it like
$data = User::getData(array('first_name' => 'Jhon'));