PdoStatement->bindParam() 上的字符串编码问题?

发布于 2024-08-20 16:06:34 字数 841 浏览 5 评论 0原文

我正在尝试从 $_REQUEST var 中获取的字符串执行简单的 SELECT 语句,但我的 PDO 语句似乎不喜欢该字符串格式,为什么?

我的 $_REQUEST var 包含像 Hello+World 这样的字符串,因此我需要用空格替换 + 来执行我的 SELECT 语句正确。

// the data returned is Hello+World
$phrase = str_replace ("+", " ", $_REQUEST["my_data"]);

$phrase_select = $connection->prepare ("SELECT data_field FROM my_table WHERE phrase = ':phrase'");
$phrase_select->bindParam (":phrase", $phrase, PDO::PARAM_STR);
$phrase_select->execute ();
$data_field = $phrase_select->fetchColumn (); // return nothing

如果我使用字符串“Hello+World”手动创建SELECT,它可以正常工作,但如果我使用$_REQUEST[“my_data”]执行此操作 它不起作用,我错在哪里?
如果我打印 $_REQUEST["my_data"] 它会准确返回 Hello+World

I'm trying to perform a simple SELECT statement from a string taken from a $_REQUEST var but it seem my PDO statement doesn't like the string format, why?

My $_REQUEST var contains a string like Hello+World, so I need to replace + with whitespaces to do my SELECT statement correctly.

// the data returned is Hello+World
$phrase = str_replace ("+", " ", $_REQUEST["my_data"]);

$phrase_select = $connection->prepare ("SELECT data_field FROM my_table WHERE phrase = ':phrase'");
$phrase_select->bindParam (":phrase", $phrase, PDO::PARAM_STR);
$phrase_select->execute ();
$data_field = $phrase_select->fetchColumn (); // return nothing

If I make a SELECT manually with a string "Hello+World", it works without problems, but if I do it with $_REQUEST["my_data"] it won't work, where I'm wrong?
If I print $_REQUEST["my_data"] it return exactly Hello+World

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

坏尐絯℡ 2024-08-27 16:06:34

您不必在绑定参数周围添加“..”,pdo 会为您完成此操作

you don't have to add the '..' around your bound param, pdo will do that for you

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文