首頁 >php框架 >YII >yii調試sql的方法

yii調試sql的方法

王林
王林轉載
2020-06-12 18:28:262985瀏覽

yii調試sql的方法

Yii調試SQL主要有以下方法:

一、系統自帶偵錯:

首先index.php開啟偵錯模式:

// remove the following lines when in production mode 
defined('YII_DEBUG') or define('YII_DEBUG',true); 
// specify how many levels of call stack should be shown in each log message 
defined('YII_TRACE_LEVEL') or define('YII_TRACE_LEVEL',3); 
//app use time 
//defined('YII_BEGIN_TIME') or define('YII_BEGIN_TIME',microtime(true));

main.php頁面:

'errorHandler'=>array( 
  // use 'site/error' action to display errors 
  'errorAction'=>'site/error', 
), 
'log'=>array( 
  'class'=>'CLogRouter', 
  'routes'=>array( 
    array( 
      'class'=>'CFileLogRoute', 
      'levels'=>'error, warning', 
    ), 
    // 下面显示页面日志 
    array( 
      'class'=>'CWebLogRoute', 
      'levels'=>'trace',   //级别为trace 
      'categories'=>'system.db.*' //只显示关于数据库信息,包括数据库连接,数据库执行语句 
    ),    
  ), 
),

YII_TRACE_LEVEL的數字越大,資訊越清楚

二、使用偵錯工具偵錯:

yii-debug-toolbar把包解壓縮後放到extensions裡邊然後在設定檔main.php中最後加上

'log'=>array( 
   'class'=>'CLogRouter', 
   'routes'=>array( 
     array( 
       'class'=>'ext.yii-debug-toolbar.YiiDebugToolbarRoute', 
       'ipFilters'=>array('127.0.0.1','192.168.1.215'), 
     ), 
   ), 
 ),

沒有出現的話加上在'components'下的db裡加上兩個屬性

'enableProfiling'=>true, 
'enableParamLogging'=>true,

然後如果有其他偵錯工具的插件的話,可能會出現衝突導致sql語句不出來,把那段程式碼注掉即可。

推薦教學:yii

以上是yii調試sql的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:jb51.net。如有侵權,請聯絡admin@php.cn刪除