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