yii自带的query builder很好用,省去了拼sql的过程。
在写一个语句的时候遇到这样一个问题:
$connection = yii::app()->db;$command = $connection->createcommand();$operate_rst = 0;if(!empty($_post['lid'])){ $operate_rst = $command->update('emg_landing', $landing_info, 'lid=:lid', array(':lid' => $_post['lid']));}else{ $operate_rst = $command->insert('emg_landing', $landing_info);}$connection->active = false;if($operate_rst > 0){ functions::returnok('ok!');}functions::returnerrorjson();
复制代码
用 $operate_rst 来记录操作结果,执行新建insert没有问题,但是在更新时候,有时会显示操作失败,检查了半天,也找不到原因,只好去翻文档http://www.yiiframework.com/doc/api/1.1/cdbcommand#update-detail看到return那一项:{return} integer number of rows affected by the execution.有时可能没有改数据但是触发了更新操作,所以这时候受更改的行数为0,返回的判断就进入到错误代码里。同理,delete() 和 insert() 的方法返回值意义也是受到影响的行数,所以delete和insert可以根据返回值是否大于0来判断操作是否成功,但是update操作不一定,返回值为0也有可能表示对db操作成功。
