经常看到有人问到findall的返回数据类型是什么之类的问题,以及出错了不知道什么原因的情况,其实还是没有熟悉thinkphp内置的调试手段和方法,抛开ide本身自带的调试方式不说,如果你正在用或者打算用thinkphp开发的话,那么下面一些和调试thinkphp程序相关的方法你是应该要了解和掌握的。
1、在项目配置文件里面打开调试模式debug_mode,这样能够让你发现大部分的错误原因 。可能影响验证码的输出。
2、如果不想使用调试模式,可以单独开启页面trace显示。发现很多人不想使用调试模式的原因居然是因为有页面trace信息的输出,其实这里面有一个误区,以为调试模式就一定会有页面trace,但其实调试模式和页面trace没有必然的关系,只是因为打开调试模式后,系统默认的调试配置文件会开启页面trace显示,所以你完全可以给项目单独定义调试配置文件。
3、使用系统定义的dump函数,该方法同var_dump可以输出任何类型的变量信息,而且更加有利于在浏览器里面查看,例如:
$user=d(user);$list=$user->findall();dump($list);
4、页面trace信息只能显示当前页面执行的sql语句,但无法查看ajax方式执行的后台操作里面的sql语句,所以你还可以开启sql日志记录sql_debug_log来记录每一条执行的sql语句,并且可以查看到每条sql语句的执行时间 sql日志文件位于logs目录下面,会自动按日期来区分每天的sql日志。
5、另外一个是在执行某个数据操作后怀疑sql执行有错误的话,可以使用模型类的getlastsql方法来查看上次执行的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、当需要调试某段代码的运行时间的时候,可以使用系统提供的debug_start($label)和debug_end($label)方法,例如:
debug_start('demo');//这里是你的代码段.......debug_end('demo');
您可能感兴趣的文章thinkphp模板中判断volist循环的最后一条记录thinkphp页面跳转(successerror)如何设置跳转等待时间thinkphp打印最后一条sql语句thinkphp自动验证与自动填充无效的解决办法thinkphp 的 action 控制器中的系统常量总结thinkphp中的查询技巧总结thinkphp内置模板引擎的使用方法总结thinkphp关闭缓存的方法
http://www.bkjia.com/phpjc/764142.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/764142.htmltecharticle经常看到有人问到findall的返回数据类型是什么之类的问题,以及出错了不知道什么原因的情况,其实还是没有熟悉thinkphp内置的调试手段和...