我觉得我错过了什么。
我试图在:中使用bindParam分隔符,但没有成功。
PHP:
$te = 'test';
$tesql = "select charname from characters where username = :user;";
$stmt = $db->prepare($tesql);
$stmt->bindParam(':user',$te,PDO::PARAM_STR,100);
$stmt->execute();
echo $stmt->queryString;queryString显示:
select charname from characters where username = :user;如何让$te代替:user显示?
发布于 2014-03-09 01:03:33
您不能让$te代替:user来显示。当使用准备好的语句时,首先使用占位符将语句发送到服务器(转换为MySQL的问号,因为它本机不支持命名占位符),然后在执行execute()时将数据单独发送到服务器。他们就是这样工作的。如果需要实际值而不是占位符,则需要启用MySQL日志记录并检查服务器日志,但是,如果启用了PDO模拟查询,则只会看到实际的SQL语句。
https://stackoverflow.com/questions/22277113
复制相似问题