How to print executed SQL statements in laravel (two methods)
It is a common thing to use Eloquent ORM to query the database in Laravel, but when we face some complex query requirements, we need to debug by viewing the executed SQL statements. So how to print the executed SQL statements?
Laravel provides two ways to print executed SQL statements, one is through log output, and the other is through event listener printing.
Through log output
SQL statements executed through log output in Laravel are the most convenient way, and there are corresponding log recording and viewing methods in each environment.
We can turn on the logging of SQL statements in the configuration file:
// 在config/database.php文件中,找到default下的connections数组,增加以下选项: 'log_queries' => true, // 开启SQL日志记录 'log_channel' => 'daily', // 日志存储方式,也可使用syslog、errorlog等方式 'log_level' => 'debug', // 日志级别
After adding the log_queries option, Laravel will automatically record the executed SQL statements, and the logs will be output to the storage/logs directory.
After executing the query statement in the code, we can output the SQL statement in the following way:
DB::enableQueryLog(); // 执行查询语句 $users = DB::table('users')->get(); // 获取执行的SQL语句 $sql = DB::getQueryLog()[0]['query'];
In the above code, first call the DB::enableQueryLog() method to enable recording of the SQL statement , after executing the query, you can obtain all executed SQL statements through the DB::getQueryLog() method. If you want to obtain the last SQL statement, you can also use the DB::getLastQuery() method.
However, it should be noted that using this method to record a large number of SQL statements in the production environment will cause the log volume to increase, which is not conducive to system maintenance and troubleshooting. Therefore, do not frequently record SQL statements in the production environment. Statement log.
Through the event listener
Laravel provides a way to listen to SQL execution events. Developers can output SQL statements by listening to SQL execution events. This method is safer and more reliable and will not be used in production. A large number of logs are generated in the environment.
By defining a listener, the corresponding SQL statement can be printed out when executing any query statement. The following is the implementation code:
// 在AppServiceProvider的boot方法中,添加以下代码 use Illuminate\Support\Facades\DB; use Illuminate\Database\Events\QueryExecuted; use Log; // 注册SQL执行监听器 DB::listen(function (QueryExecuted $queryExecuted) { $sql = str_replace("?", "'%s'", $queryExecuted->sql); $bindings = $queryExecuted->connection->prepareBindings($queryExecuted->bindings); $fullSql = vsprintf($sql, $bindings); Log::debug('SQL:'.$fullSql); });
In the above code, we use DB::listen() to register an event listener, which will be triggered when any query statement is executed.
In the listener, the SQL statement of the current query and related binding parameters and other information are obtained through the QueryExecuted event, and then output to the log through the Log::debug() method.
Through the above two methods, we have achieved the purpose of printing SQL statements in Laravel, which can make debugging and troubleshooting more convenient, and plays an irreplaceable role in development.
The above is the detailed content of How to print executed SQL statements in laravel (two methods). For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Laravel is a PHP framework for easy building of web applications. It provides a range of powerful features including: Installation: Install the Laravel CLI globally with Composer and create applications in the project directory. Routing: Define the relationship between the URL and the handler in routes/web.php. View: Create a view in resources/views to render the application's interface. Database Integration: Provides out-of-the-box integration with databases such as MySQL and uses migration to create and modify tables. Model and Controller: The model represents the database entity and the controller processes HTTP requests.

Laravel provides a comprehensive Auth framework for implementing user login functions, including: Defining user models (Eloquent model), creating login forms (Blade template engine), writing login controllers (inheriting Auth\LoginController), verifying login requests (Auth::attempt) Redirecting after login is successful (redirect) considering security factors: hash passwords, anti-CSRF protection, rate limiting and security headers. In addition, the Auth framework also provides functions such as resetting passwords, registering and verifying emails. For details, please refer to the Laravel documentation: https://laravel.com/doc

How does Laravel play a role in backend logic? It simplifies and enhances backend development through routing systems, EloquentORM, authentication and authorization, event and listeners, and performance optimization. 1. The routing system allows the definition of URL structure and request processing logic. 2.EloquentORM simplifies database interaction. 3. The authentication and authorization system is convenient for user management. 4. The event and listener implement loosely coupled code structure. 5. Performance optimization improves application efficiency through caching and queueing.

Article summary: This article provides detailed step-by-step instructions to guide readers on how to easily install the Laravel framework. Laravel is a powerful PHP framework that speeds up the development process of web applications. This tutorial covers the installation process from system requirements to configuring databases and setting up routing. By following these steps, readers can quickly and efficiently lay a solid foundation for their Laravel project.

The Laravel framework has built-in methods to easily view its version number to meet the different needs of developers. This article will explore these methods, including using the Composer command line tool, accessing .env files, or obtaining version information through PHP code. These methods are essential for maintaining and managing versioning of Laravel applications.

In the Laravel framework version selection guide for beginners, this article dives into the version differences of Laravel, designed to assist beginners in making informed choices among many versions. We will focus on the key features of each release, compare their pros and cons, and provide useful advice to help beginners choose the most suitable version of Laravel based on their skill level and project requirements. For beginners, choosing a suitable version of Laravel is crucial because it can significantly impact their learning curve and overall development experience.

Want to learn the Laravel framework, but suffer from no resources or economic pressure? This article provides you with free learning of Laravel, teaching you how to use resources such as online platforms, documents and community forums to lay a solid foundation for your PHP development journey from getting started to master.

Laravel and ThinkPHP are both popular PHP frameworks and have their own advantages and disadvantages in development. This article will compare the two in depth, highlighting their architecture, features, and performance differences to help developers make informed choices based on their specific project needs.
