資料庫常見問題:無法取得查詢 Log

在 Laravel 4 為了要確定下的 SQL 語法有符合我們預期,我們常常在做完資料庫查詢後,使用 DB::getQueryLog(); 去取得做資料庫查詢的 Qeury Log,但因為 Laravel 會把這些 Log 都記錄在記憶體中,如果做了大量的新增的查詢,記憶體會使用過多可能會造成系統 Crash。

所以 Laravel 5 預設把記錄 Query Log 的機制關閉,若需要做 Query Debug,需要自行打開 Qeury Log 功能

<?php
// 啟用 Query Log 功能
DB::connection()->enableQueryLog();

這樣我們就可以使用 DB::getQueryLog(); 去取得做資料庫查詢的 Qeury Log 摟!! 要得到執行過的查詢紀錄陣列,你可以使用 getQueryLog 方法:

<?php
// 取得資料庫查詢的 Qeury Log
$queries = DB::getQueryLog();

var_dump($queries);

參考資料

KeJyun 最新新書推薦
- Laravel 5 for beginner 新手道場:優雅運用框架快速開發 PHP 網站
- Laravel框架开发详解:从零基础到运用框架快速开发PHP网站

Laravel 是 PHP 的框架(Framework),提供了很多開發網站或 API 所需的工具及環境,經過簡單的設定就可以完成資料的處理及顯示,使開發者可以很優雅且快速的開發出各個不同的產品。本書適合有 PHP 基礎的人,但不知道要怎麼選擇框架,或者不用框架的人也能夠明白它的好處。

雖然 WordPress 也能夠架站,但如果有客製化需求,要開發各式各樣的網站,或提供 App 使用的 API,如此一來你只能選擇用框架,而 Laravel 是目前最受歡迎的。

本書將解說為什麼要使用框架,以及理解框架的優缺點後,要怎麼選擇框架,並用框架快速建構一個網站。除非必要,否則書中會避免專業技術用語,盡量使用最生活化易懂的例子及語氣,讓大家更容易進入 Laravel 的世界。

Laravel 5 for beginner 新手道場:優雅運用框架快速開發 PHP 網站

購書連結

Laravel框架开发详解:从零基础到运用框架快速开发PHP网站

購書連結

comments powered by Disqus