overtrue/laravel-query-logger

A dev tool to log all queries for laravel application.

Maintainers

👁 overtrue

Package info

github.com/overtrue/laravel-query-logger

pkg:composer/overtrue/laravel-query-logger

Fund package maintenance!

overtrue

Statistics

Installs: 321 287

Dependents: 6

Suggesters: 0

Stars: 407

Open Issues: 12

v5.1.0 2026-03-21 14:24 UTC

Requires

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT b09af8efab57b48b6d5ed3d49096398600615c5d

  • overtrue <anzhengchao.woop@gmail.com>

This package is auto-updated.

Last update: 2026-06-16 06:27:35 UTC


README

📝 A dev tool to log all queries for Laravel application.

👁 Sponsor me

Installing

$ composer require overtrue/laravel-query-logger -vvv

Laravel Query Logger will be enabled when LOG_QUERY is true.

Usage

$ tail -f ./storage/logs/laravel.log
[2017-09-05 14:52:14] local.DEBUG: [800μs] select count(*) as aggregate from `discussions` where `discussions`.`deleted_at` is null | GET: http://laravel.app/discussions
[2017-09-05 14:52:14] local.DEBUG: [1.07ms] select * from `discussions` where `discussions`.`deleted_at` is null order by `is_top` desc, `created_at` desc limit 15 offset 0 | GET: http://laravel.app/discussions
[2017-09-05 14:52:14] local.DEBUG: [3.63s] select `tags`.*, `taggables`.`taggable_id` as `pivot_taggable_id`, `taggables`.`tag_id` as `pivot_tag_id` from `tags` inner join `taggables` on `tags`.`id` = `taggables`.`tag_id` where `taggables`.`taggable_id` in ('1', '2', '3', '4', '5', '6', '7', '8') and `taggables`.`taggable_type` = 'App\\Models\\Discussion' order by `order_column` asc | GET: http://laravel.app/discussions
[2017-09-05 14:52:14] local.DEBUG: [670μs] select * from `users` where `users`.`id` in ('1', '2', '4') and `users`.`deleted_at` is null | GET: http://laravel.app/discussions
...

Configuration

You can also control whether to log a query via the configuration file:

config/logging.php:

return [
 //...
 'query' => [
 'enabled' => env('LOG_QUERY', env('APP_ENV') === 'local'),
 
 // Only record queries that are slower than the following time
 // Unit: milliseconds
 'slower_than' => 0,
 
 // Only record queries when the QUERY_LOG_TRIGGER is set in the environment, 
 // or when the trigger HEADER, GET, POST, or COOKIE variable is set.
 'trigger' => env('QUERY_LOG_TRIGGER'),

 // Except record queries
 'except' => [
 // '*_telescope_*',
 ],
 
 // Log Channel
 'channel' => 'stack',
 ],
];

❤️ Sponsor me

👁 Sponsor me

如果你喜欢我的项目并想支持它,点击这里 ❤️

Project supported by JetBrains

Many thanks to Jetbrains for kindly providing a license for me to work on this and other open-source projects.

👁 Image

PHP 扩展包开发

想知道如何从零开始构建 PHP 扩展包?

请关注我的实战课程,我会在此课程中分享一些扩展开发经验 —— 《PHP 扩展包实战教程 - 从入门到发布》

License

MIT