【问题标题】:Use prepared statements in MySQL-PHP-Code在 MySQL-PHP-Code 中使用准备好的语句
【发布时间】:2016-01-17 09:22:24
【问题描述】:

我是新手,所以我的问题可能有点奇怪。我正在尝试对以下代码使用准备好的语句:

<?php
require_once(__DIR__.'/config.php');


$value = $_POST["value"];
$ort = $_GET["ort"];


$stmt = $pdo->prepare('SELECT * FROM Suchmaschine WHERE firma = :firma AND ort = :ort');
$stmt->execute(array('firma' => $value, 'ort' => $value));

foreach ($stmt as $row) {   
   echo "<a href=".$row['link'].">".$row['firma']."</a><br>";
}
?>

我尝试了一些方法,但它不起作用。

【问题讨论】:

  • 请添加您无法使用的准备好的语句的代码。
  • 'ort' =&gt; $value 好像错了
  • 'ort' =&gt; $ort 更有可能
  • 谢谢,但没有帮助。还是没有输出。我能做些什么?我想从 column Firma=$_POST["value"]; 的所有行中回显链接和firma。和列 ort=$_GET["ort"];

标签: php mysql prepared-statement sql-like


【解决方案1】:

首先,您缺少的这一行:和错误的变量名应该是:

$stmt->execute(array(':firma' => $value, ':ort' => $ort));

那么你没有获取结果。

$results = $stmt->fetchAll();

foreach( $results as $row ) {
        echo "<a href=".$row['link'].">".$row['firma']."</a><br>";
}

【讨论】:

  • 谢谢,我收到这个错误:解析错误:语法错误,意外'as'(T_AS),期待';'在 /var/www/username/html/folder/folder2/file.php 第 14 行
  • 谢谢,现在没有错误了。但仍然是一个问题。例如。我的表中有“示例”一词。如果我搜索“示例”,则搜索有效。但是,如果我搜索“exam”,因为不是整个单词,所以我找不到匹配项。请你也帮我看看好吗?
【解决方案2】:

问题出在以下行:

$stmt->execute(array('firma' => $value, 'ort' => $value));

应该改为:

$stmt->execute(array(':firma' => $value, ':ort' => $value));

请注意,在作为键传递给执行语句的数组的字符串前面添加了冒号。

请看这里:http://php.net/manual/en/pdostatement.execute.php

【讨论】:

  • executebind 语句中占位符名称中的冒号是可选的。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-07-27
  • 2016-09-10
  • 1970-01-01
  • 1970-01-01
  • 2011-09-16
相关资源
最近更新 更多