1 回答
TA贡献1946条经验 获得超3个赞
这个有很多种方法
1. yii有提供一个 getRawSql方法 比如说一个查询
1 2 3 4 | $query = User::find(); $query->select(['username','age'])->where(['id'=>1)->one();
echo $query->createCommand()->getRawSql();//输出sql语句 |
2.可开启yii2的debug模块,这个功能很强大,在里面可以查到当前页面所有的sql信息,具体配置方法自行百度,网上太多这个配置了
3.查找Yii源码 随便找个模型调用原生的方法 比如 User::updateAll 方法,通过编辑器定位到updateAll方法的源码 你会发现下面一段代码
1 2 3 4 5 6 7 | public static function updateAll($attributes, $condition = '', $params = []) { $command = static::getDb()->createCommand(); $command->update(static::tableName(), $attributes, $condition, $params);
return $command->execute(); } |
继续定位execute方法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 | public function execute() { $sql = $this->getSql(); $rawSql = $this->getRawSql();
Yii::info($rawSql, __METHOD__); if ($sql == '') { return 0; }
$this->prepare(false); $token = $rawSql; try { Yii::beginProfile($token, __METHOD__);
$this->pdoStatement->execute(); $n = $this->pdoStatement->rowCount();
Yii::endProfile($token, __METHOD__);
$this->refreshTableSchema();
return $n; } catch (\Exception $e) { Yii::endProfile($token, __METHOD__); throw $this->db->getSchema()->convertException($e, $rawSql); } } |
方法里 $rawSql就是最原生要执行的sql拉,在这里打断点输出就ok
- 1 回答
- 0 关注
- 646 浏览
添加回答
举报