En este post te mostraré cómo obtener el código SQL que Laravel ejecuta al usar el ORM. Es decir, obtener el SQL generado por Eloquent. Por ejemplo, si tú haces un DB::table("productos")->all();
te mostraré cómo obtener la consulta generada que sería SELECT * FROM productos
.
Todo esto que te menciono es útil al depurar, pues así puedes ver si te estás equivocando en algún método. Además, también sirve para aprender Laravel, pues se puede observar cómo es que los métodos modifican a la consulta interna.
Para obtenerlo como cadena, simplemente invoca a toSql
al final de todos los métodos encadenados. Por ejemplo, lo siguiente:
<?php
DB::table("ventas")
->join("productos_vendidos", "productos_vendidos.id_venta", "=", "ventas.id")
->where("ventas.created_at", ">=", $haceMeses)
->where("ventas.created_at", "<=", $hoy)
->where("ventas.id_cliente", "=", $idCliente)
->where("productos_vendidos.codigo_barras", "=", $codigoBarras)
->toSql();
Tendrá la siguiente salida:
select * from `ventas` inner join `productos_vendidos` on `productos_vendidos`.`id_venta` = `ventas`.`id` where `ventas`.`created_at` >= ? and `ventas`.`created_at` <= ? and `ventas`.`id_cliente` = ? and `productos_vendidos`.`codigo_barras` = ?
Recuerda que Laravel previene las inyecciones SQL, así que los verdaderos valores serán pasados después, y en la consulta son indicados con ?.
Esto fue un ejemplo sencillo, pero en resumen, invoca a toSql que devolverá como string el SQL que se va a ejecutar.
En este post te quiero compartir un código de C++ para listar y cancelar trabajos…
Gracias a WebAssembly podemos ejecutar código de otros lenguajes de programación desde el navegador web…
Revisando y buscando maneras de imprimir un PDF desde la línea de comandos me encontré…
Esta semana estuve recreando la API del plugin para impresoras térmicas en Android (HTTP a…
Hoy te enseñaré a extraer la cadena base64 de una clave PEM usando una función…
Encender un foco con un Bot de Telegram es posible usando una tarjeta como la…
Esta web usa cookies.
Ver comentarios
Aprovecho éste medio para saludarte y darte las gracias por tus aportes gratuitos en todos estos temas de programación, te deseo de mi parte mucho éxito porque eres una gran persona solidaria...
Hola. Muchas gracias por sus comentarios, le deseo éxito.
Saludos :)