php - Yii CDBCommand getText 显示 SQL 中的所有变量

标签 php yii

我正在使用 Yii 的 Yii::app()->db->createCommand() 来构建 SQL 查询。为了查看 Yii 生成的 SQL 代码,我使用了 CDBCommand 的 getText() 方法。问题是,当我在包含参数的 SQL 代码上使用 getText() 方法时,例如:

Yii::app()->db->createCommand()
           ->select("name")
           ->from('package')
           ->where('id=:id', array(':id'=>5))
           ->queryRow();

getText() 方法返回以下 SQL:

select name from package where id=:id

代替:

select name from package where id=5

这对于简单的查询来说很好,但是对于具有大量参数的更复杂的查询,将每个参数复制/粘贴到 SQL 代码中进行测试是相当痛苦的。

有没有办法使用 getText() 或 Yii 中的其他方法直接在 SQL 中显示参数?

干杯!

最佳答案

$sql = Yii::app()->db->createCommand()
  ->select("name")
  ->from('package')
  ->where('id=:id', array(':id'=>5))
  ->queryRow();

$query=str_replace(
   array_keys($sql->params),
   array_values($sql->params),
   $sql->getText()
);

关于php - Yii CDBCommand getText 显示 SQL 中的所有变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9226625/

相关文章:

yii - 模型中的更新记录- YII 框架

Yii 根据用户动态数据库连接?

phpunit在phpstorm中运行问题,无法创建phar

php - Yii2 - JSONP 响应不返回任何内容(空白)并且不起作用,但 JSON 可以

php - Yii1 MYSQL 连接 4 个表,其中类和组

yii - 如何将 yii 1 应用程序转换为版本 2

php - 如何在 php 中编写一个可以像 func(a)(b)(c) 一样调用的函数?

php - WordPress 表关联

php - Jquery Ajax 响应在 Firefox 上不起作用

php - 来自 PHP exec() 的 Node 模块命令不起作用