We're using Doctrine, a PHP ORM. I am creating a query like this:
$q = Doctrine_Query::create()->select('id')->from('MyTable');
and then in the function I'm adding in various where clauses and things as appropriate, like this
$q->where('normalisedname = ? OR name = ?', array($string, $originalString));
Later on, before execute()
-ing that query object, I want to print out the raw SQL in order to examine it, and do this:
$q->getSQLQuery();
However that only prints out the prepared statement, not the full query. I want to see what it is sending to the MySQL, but instead it is printing out a prepared statement, including ?
's. Is there some way to see the 'full' query?
An example..
Show SQL:
$sql=$query->getSQL();
Show Parameters:
$parameters=$query->getParameters();
You can easily access the SQL parameters using the following approach.
So if you printed out the
$param_values
and$col_names
, you can get the parameter values passing through the sql and respective column names.Note : If
$param
returns an array, you need to re iterate, as parameters insideIN (:?)
usually comes is as a nested array.Meantime if you found another approach, please be kind enough to share with us :)
Thank you!
You can use :
If you are using MySQL you can use Workbench to view running SQL statements. You can also use view the running query from mysql by using the following :
Doctrine is not sending a "real SQL query" to the database server : it is actually using prepared statements, which means :
$query->getSql()
)$query->getParameters()
)This means there is never a "real" SQL query on the PHP side — so, Doctrine cannot display it.
To print out an SQL query in Doctrine, use: