Development

How to debug and view a Laravel DB query

How to view a raw Laravel database query from the DB facade with its bindings.

This is a good method to debug if your queries with the query builder are failing or getting unexpected results.

You must enable query logging with DB::enableQueryLog(); and then proceed with the query

DB::enableQueryLog();

$new_users = DB::table('users')
    ->where('created', '>=', '2022-03-01')
    ->orderBy('created', 'desc')
    ->get();

dd(DB::getQueryLog());

This will output

[
  {
    "query": "select * from `users` where `created` >= ? order by `created` desc",
    "bindings": [
      "2022-03-01"
    ],
    "time": 4.13
  }
]

Where you have the pure query with the pre-prepared statements and then the binding value/s, with the execution time to conclude.

The query logger works for all query types eg. INSERT, UPDATE, DELETE and SELECT however using it in a loop could overload memory.

Share

Recent Posts

Kennington reservoir drained drone images

A drained and empty Kennington reservoir images from a drone in early July 2024. The…

1 year ago

Merrimu Reservoir drone images

Merrimu Reservoir from drone. Click images to view larger.

1 year ago

FTP getting array of file details such as size using PHP

Using FTP and PHP to get an array of file details such as size and…

2 years ago

Creating Laravel form requests

Creating and using Laravel form requests to create cleaner code, separation and reusability for your…

2 years ago

Improving the default Laravel login and register views

Improving the default Laravel login and register views in such a simple manner but making…

2 years ago

Laravel validation for checking if value exists in the database

Laravel validation for checking if a field value exists in the database. The validation rule…

2 years ago