解析使用ThinkPHP應(yīng)該掌握的調(diào)試手段
使用ThinkPHP應(yīng)該掌握的調(diào)試手段
經(jīng)常看到有人問到findAll的返回數(shù)據(jù)類型是什么之類的問題,以及出錯了不知道什么原因的情況,其實還是沒有熟悉ThinkPHP內(nèi)置的調(diào)試手段和方法,拋開IDE本身自帶的調(diào)試方式不說,如果你正在用或者打算用ThinkPHP開發(fā)的話,那么下面一些和調(diào)試相關(guān)的方法你是應(yīng)該要了解和掌握的:
1、在項目配置文件里面打開調(diào)試模式DEBUG_MODE,這樣能夠讓你發(fā)現(xiàn)大部分的錯誤原因 。可能影響驗證碼的輸出。
2、如果不想使用調(diào)試模式,可以單獨開啟頁面Trace顯示。發(fā)現(xiàn)很多人不想使用調(diào)試模式的原因居然是因為有頁面Trace信息的輸出,其實這里面有一個誤區(qū),以為調(diào)試模式就一定會有頁面Trace,但其實調(diào)試模式和頁面Trace沒有必然的關(guān)系,只是因為打開調(diào)試模式后,系統(tǒng)默認的調(diào)試配置文件會開啟頁面Trace顯示,所以你完全可以給項目單獨定義調(diào)試配置文件。
3、使用系統(tǒng)定義的dump函數(shù),該方法同var_dump可以輸出任何類型的變量信息,而且更加有利于在瀏覽器里面查看,例如:
$User = D("User");
$list = $User->findAll();
dump($list);
4、頁面Trace信息只能顯示當前頁面執(zhí)行的sql語句,但無法查看ajax方式執(zhí)行的后臺操作里面的sql語句,所以你還可以開啟sql日志記錄SQL_DEBUG_LOG 來記錄每一條執(zhí)行的sql語句,并且可以查看到每條sql語句的執(zhí)行時間 sql日志文件位于Logs目錄下面,會自動按日期來區(qū)分每天的sql日志。
5、另外一個是在執(zhí)行某個數(shù)據(jù)操作后懷疑sql執(zhí)行有錯誤的話,可以使用模型類的getLastSql方法來查看上次執(zhí)行的sql語句,以便分析具體的錯誤原因。例如:
$User = D("User");
$User->id = 3;
$User->name = 'ThinkPHp';
$User->save();
echo $User->getLastSql();
// 輸出 update think_user set name='ThinkPHP' where id=3;
6、當需要調(diào)試某段代碼的運行時間的時候,可以使用系統(tǒng)提供的debug_start($label)和debug_end($label)方法,例如:
debug_start('demo');
// 這里是你的代碼段.......
debug_end('demo');
- thinkPHP框架中執(zhí)行原生SQL語句的方法
- thinkphp中多表查詢中防止數(shù)據(jù)重復(fù)的sql語句(必看)
- 解決ThinkPHP關(guān)閉調(diào)試模式時報錯的問題匯總
- ThinkPHP調(diào)試模式與日志記錄概述
- thinkphp中常用的系統(tǒng)常量和系統(tǒng)變量
- ThinkPHP模版引擎之變量輸出詳解
- thinkPHP5.0框架環(huán)境變量配置方法
- 解析thinkphp import 文件內(nèi)容變量失效的問題
- thinkPHP控制器變量在模板中的顯示方法示例
- ThinkPHP框架獲取最后一次執(zhí)行SQL語句及變量調(diào)試簡單操作示例
相關(guān)文章
在WordPress中實現(xiàn)評論頭像的自定義默認和延遲加載
這篇文章主要介紹了在WordPress中實現(xiàn)評論頭像的自定義默認和延遲加載,需要的朋友可以參考下2015-11-11PHP聚合式迭代器接口IteratorAggregate用法分析
這篇文章主要介紹了PHP聚合式迭代器接口IteratorAggregate用法,結(jié)合實例形式分析了聚合式迭代器接口IteratorAggregate的概念、功能、定義及使用方法,需要的朋友可以參考下2017-12-12提示Trying to clone an uncloneable object of class Imagic的解決
使用網(wǎng)上流傳的一個程序?qū)崿F(xiàn)pdf截圖為png,需要使用Imagic擴展,安裝后出現(xiàn)Trying to clone an uncloneable object of class Imagic提示,下面是具體的解決方法分享。2011-10-10淺析Apache中RewriteCond規(guī)則參數(shù)的詳細介紹
Apache中 RewriteCond語句對于我來說一直是個難點,多次試圖去把它搞明白,都沒有結(jié)構(gòu),這次我終于算大概知道它的意思了2013-06-06