解析使用ThinkPHP应该掌握的调试手段
2013-06-20 00:00
429 查看
使用ThinkPHP应该掌握的调试手段
经常看到有人问到findAll的返回数据类型是什么之类的问题,以及出错了不知道什么原因的情况,其实还是没有熟悉ThinkPHP内置的调试手段和方法,抛开IDE本身自带的调试方式不说,如果你正在用或者打算用ThinkPHP开发的话,那么下面一些和调试相关的方法你是应该要了解和掌握的:
1、在项目配置文件里面打开调试模式DEBUG_MODE,这样能够让你发现大部分的错误原因 。可能影响验证码的输出。
2、如果不想使用调试模式,可以单独开启页面Trace显示。发现很多人不想使用调试模式的原因居然是因为有页面Trace信息的输出,其实这里面有一个误区,以为调试模式就一定会有页面Trace,但其实调试模式和页面Trace没有必然的关系,只是因为打开调试模式后,系统默认的调试配置文件会开启页面Trace显示,所以你完全可以给项目单独定义调试配置文件。
3、使用系统定义的dump函数,该方法同var_dump可以输出任何类型的变量信息,而且更加有利于在浏览器里面查看,例如:
4、页面Trace信息只能显示当前页面执行的sql语句,但无法查看ajax方式执行的后台操作里面的sql语句,所以你还可以开启sql日志记录SQL_DEBUG_LOG 来记录每一条执行的sql语句,并且可以查看到每条sql语句的执行时间 sql日志文件位于Logs目录下面,会自动按日期来区分每天的sql日志。
5、另外一个是在执行某个数据操作后怀疑sql执行有错误的话,可以使用模型类的getLastSql方法来查看上次执行的sql语句,以便分析具体的错误原因。例如:
6、当需要调试某段代码的运行时间的时候,可以使用系统提供的debug_start($label)和debug_end($label)方法,例如:
经常看到有人问到findAll的返回数据类型是什么之类的问题,以及出错了不知道什么原因的情况,其实还是没有熟悉ThinkPHP内置的调试手段和方法,抛开IDE本身自带的调试方式不说,如果你正在用或者打算用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应该掌握的调试手段
- 解析使用ThinkPHP应该掌握的调试手段
- 使用ThinkPHP应该掌握的调试手段
- 使用ThinkPHP应该掌握的调试手段
- 【转】使用ThinkPHP必须掌握的调试方法
- 使用ThinkPHP必须掌握的调试方法
- 使用ThinkPHP必须掌握的调试方法
- IDEA 15:DeBug(调试)模式的使用,你应该学会找代码报错的地方
- ThinkPHP-路由解析的实现和(开发调试模式的实现)
- 关于thinkphp 中 使用 token_get_all() 源码解析
- php/thinkphp使用PHPExcel解析表格数据,生成表格案例
- 在使用thinkphp框架时,在模板中尽量少使用php代码段,会导致不解析的后果
- 【thinkphp3.x】thinkphp3.x中使用show方法进行内容解析输出
- ACEXML解析XML文件——我是如何学习并在短时间内掌握一个库的使用方法的
- WordPress中调试缩略图的相关PHP函数使用解析
- Android解析之三分钟教你快速掌握并使用GSON解析Json
- thinkphp使用literal防止模板标签被解析的方法
- Thinkphp3.2.3分页使用实例解析
- 大家都应该掌握的PHP关联数组使用技巧
- (转帖)使用OpenFileDialog对话框打开文本文件(写此代码的人应该是有一定功力的程序员,因为代码写的很规范,很容易阅读,很好理解,很好调试)