Resultado no deseado de db:raw
Pregunta
He tomado algunas respuestas tanto de SO como de los foros de Laravel para reconstruir los resultados.Sin embargo, estoy teniendo un Undefined variable error
y no estoy seguro de por qué.
Controlador
public function getJobs()
{
$query = DB::table('jobs');
if (isset($jcategory))
$query->where('category', '=', $jcategory);
$result = $query->get();
return View::make('jobsearch.search', $result);
}
Ver (ha sido abreviado por espacio)
<form action="{{ action('JobsearchController@getJobs') }}" method="post">
<div class="row">
<div class="large-8 columns">
<input type="text" name="realm" placeholder="Keywords/Skills" />
</div>
<div class="large-4 columns">
<select name="jcategory">
<option value="">Select Category</option>
<option value="jc1">Accounting</option>
...
</select>
</div>
<div class="large-4 columns">
<input type="submit" value="Search" style="width:100%; padding-top: .5rem;
padding-bottom: .5rem;" class="button border-btn" />
</div>
</div>
</form>
@foreach ($result as $job)
<p>{{ $job->id }}</p>
@endforeach
Una vez que haga funcionar esta pequeña prueba, agregaré el resto del isset
en el $query
.Lo que intento lograr es que la vista cargue todos los trabajos en la base de datos y si el usuario cambia la categoría (por ejemplo) y envía la vista, recargará la página con los cambios reflejados en la consulta.
Actualmente recibo un Undefined variable: result
error en la vista.he probado el foreach
de diferentes maneras, pero tengo la sensación de que el controlador no pasa nada.
Solución
Pasaste el $result
variable de forma incorrecta.Prueba esto:
return View::make('jobsearch.search')->with('result', $result);