PHP的PDO能不能打印出上一条执行的sql语句

 我来答
吉祥二进制
高粉答主

2016-04-17 · 科技改变生活,生活改变科技。
吉祥二进制
采纳数:33926 获赞数:84565

向TA提问 私信TA
展开全部
打印sql语句,直接在你执行SQL语句后输出

$queries = DB::getQueryLog();

$a = end($queries);

$tmp = str_replace('?', '"'.'%s'.'"', $a["query"]);

echo vsprintf($tmp, $a['bindings']);

exit;
实例:

<?php
Route::get('/', function()
{
$arr['name']='zhuo';
$arr['email']='zhuowenji@163.com';
$uid = DB::table('basic')->insertGetId($arr);
$queries = DB::getQueryLog();
/*
echo '<pre>';
var_dump($queries);
echo '</pre>';
//以下为得到结果。laravel默认方式使用了pdo的形式执行对数据库操作
array(1) {
[0]=>
array(3) {
["query"]=>
string(51) "insert into `basic` (`name`, `email`) values (?, ?)"
["bindings"]=>
array(2) {
[0]=>
string(4) "zhuo"
[1]=>
string(17) "zhuowenji@163.com"
}
["time"]=>
float(2)
}
}
*/
//===========================================================
//转成源生的sql语句
if($uid == false)
{
$a = end($queries);
$tmp = str_replace('?', '"'.'%s'.'"', $a["query"]);
echo vsprintf($tmp, $a['bindings']);exit;
//结果;insert into `basic` (`name`, `email`) values ("zhuo", "zhuowenji@163.com")
}
});
?>
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式