laravel

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.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

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

Entradas recientes

Foco con Telegram, apagador de 3 vías, relevador y ESP8266

Encender un foco con un Bot de Telegram es posible usando una tarjeta como la…

5 días hace

Servidor HTTP en Android con Flutter

El día de hoy te mostraré cómo crear un servidor HTTP (servidor web) en Android…

3 semanas hace

Imprimir automáticamente todos los PDF de una carpeta

En este post te voy a enseñar a designar una carpeta para imprimir todos los…

3 semanas hace

Guía para imprimir en plugin versión 1 desde Android

En este artículo te voy a enseñar la guía para imprimir en una impresora térmica…

4 semanas hace

Añadir tasa de cambio en sistema de información

Hoy te voy a mostrar un ejemplo de programación para agregar un módulo de tasa…

1 mes hace

Comprobar validez de licencia de plugin ESC POS

Los usuarios del plugin para impresoras térmicas pueden contratar licencias, y en ocasiones me han…

1 mes hace

Esta web usa cookies.