为了账号安全,请及时绑定邮箱和手机立即绑定

yii2.0获取到最后一条执行的sql怎么看?

yii2.0获取到最后一条执行的sql怎么看?

Yii
PIPIONE 2018-08-11 17:06:25
yii2.0获取到最后一条执行的sql怎么看
查看完整描述

1 回答

?
holdtom

TA贡献1805条经验 获得超10个赞

这个有很多种方法

1. yii有提供一个 getRawSql方法  比如说一个查询

1234$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方法的源码 你会发现下面一段代码

1234567public static function updateAll($attributes$condition ''$params = []){   $command static::getDb()->createCommand();   $command->update(static::tableName(), $attributes$condition$params);    return $command->execute();}

继续定位execute方法

12345678910111213141516171819202122232425262728public 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

个人推荐第二种方法,最方法最高效,具体配置方法自己百度,很简单!


查看完整回答
反对 回复 2018-09-16
  • 1 回答
  • 0 关注
  • 1595 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信