继续我的笔记
1、还是cdbcriteria,其实对于这个类,我在上面折腾了好久。比如:
$cdb = new CDbCriteria();
$cdb->select = 'a,b,c,de';
这时候,这个select中的字段只能是主表的字段,如果你都是*的话,当然无所谓,可以直接在查询后直接$result->joinname->attributes这样调用。但是如果你只想取几个字段,怎么办?
官方的GUIDE上没有相应的例子(是我没有仔细找到),后来,蜘蛛和烂桔告诉我了,一个是说scopes一个是说直接改with,于是我选择了更改with的方法(官方AR那一节,with都是用字符串来代替的。。。),于是就变成了这样
$cdb->with['relationname'] = array('select'=>'c,d,e');
2、这回是LOG。。在LOG中显示当前页面执行的SQL时,把LOG打开就成了。。烂桔建议
PHP代码
- 'log'=>array(
- 'class'=>'CLogRouter',
- 'routes'=>array(
- array(
- 'class'=>'CFileLogRoute',
- 'levels'=>'error, warning',
- ),
- array(
- 'class' => 'CWebLogRoute',
- 'levels' => 'profile,trace',
- ),
- array(
- 'class' => 'CProfileLogRoute',
- 'levels' => 'profile',
- ),
- ),
- ),
3、DB,由于trace打开后,如果用了bindParam的话,显示的SQL可能是这样的:
SQL代码
- select xx,xx,xx from table where id IN (:yad1,:yad2,:yad3) and id = :id
'enableParamLogging'=>true,
然后在trace里面就可以看到,在显示的SQL后面,多了一个类似bindValue的值。你可以对应着查看一下,传入的值是否与你实际相对应