Laravel框架實現(xiàn)的記錄SQL日志功能示例_第1頁
Laravel框架實現(xiàn)的記錄SQL日志功能示例_第2頁
Laravel框架實現(xiàn)的記錄SQL日志功能示例_第3頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

第Laravel框架實現(xiàn)的記錄SQL日志功能示例本文實例講述了Laravel框架實現(xiàn)的記錄SQL日志功能。分享給大家供大家參考,具體如下:

在項目開發(fā)過程中或者是性能優(yōu)化中,經(jīng)常會有要查看執(zhí)行sql的情況,然而Laravel日志默認不記錄執(zhí)行sql。好在留有相關(guān)接口,我們可以很方便的就是想SQl日志功能。

在App\Providers\EventServiceProvider:class中的$listen中新增如下

protected$listen=[

'App\Events\Event'=[

'App\Listeners\EventListener',

//新增SqlListener監(jiān)聽QueryExecuted

'Illuminate\Database\Events\QueryExecuted'=[

'App\Listeners\SqlListener',

新建SqlListener監(jiān)聽器

方法1,手動創(chuàng)建,在App\Listeners\SqlListener.php文件,內(nèi)容如下

namespaceApp\Listeners;

useIlluminate\Database\Events\QueryExecuted;

classSqlListener{

*Createtheeventlistener.

*@returnvoid

publicfunction__construct(){

*Handletheevent.

*@param=QueryExecuted$event

*@returnvoid

publicfunctionhandle(QueryExecuted$event){

//在這里編寫業(yè)務(wù)邏輯

方法2,使用命令行創(chuàng)建,命令如下

//該命令必須在項目跟目錄下執(zhí)行,因為項目跟目錄下才有artisan文件。

//該命令可以自動創(chuàng)建SqlListener文件,但是QueryExecuted這個類的導(dǎo)入可能會有點問題,自己改下。

phpartisanmake:listenerSqlListener-e=QueryExecuted

在handle方法中編寫記錄sql的業(yè)務(wù)邏輯,如:

*Handletheevent.

*@param=QueryExecuted$event

*@returnvoid

publicfunctionhandle(QueryExecuted$event){

$sql=str_replace("","'%s'",$event-sql);

$log=vsprintf($sql,$event-bindings);

$log='['.date('Y-m-dH:i:s').']'.$log."\r\n";

$filepath=storage_path('logs\sql.log');

file_put_contents($filepath,$log,FILE_APPEND);

//這里也可以直接用Log::info()里的函數(shù),只是這樣會和其他調(diào)試信息摻在一起。

//如果要用Log里的函數(shù),別忘記了引入Log類。

更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論