Laravel: obtener SQL generado por ORM

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.

Obtener SQL generado por Laravel

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.

Estoy aquí para ayudarte 🤝💻


Estoy aquí para ayudarte en todo lo que necesites. Si requieres alguna modificación en lo presentado en este post, deseas asistencia con tu tarea, proyecto o precisas desarrollar un software a medida, no dudes en contactarme. Estoy comprometido a brindarte el apoyo necesario para que logres tus objetivos. Mi correo es parzibyte(arroba)gmail.com, estoy como@parzibyte en Telegram o en mi página de contacto

No te pierdas ninguno de mis posts 🚀🔔

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.

2 comentarios en “Laravel: obtener SQL generado por ORM”

  1. 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…

Dejar un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *