PHP 绑定(bind)变量、无效参数号错误或 PDO 更新语句

标签 php mysql pdo

我使用 PDO 在 PHP 中构建了更新语句,但是我不断收到此错误。

ERROR: SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens

我数了又数(25),并花了一段时间确保我的语法正确,但我不明白我做错了什么。

这是代码:

$sql = "UPDATE :tablename
        SET entryName = :entryname,
        entryAdd1 = : add1,
        entryAdd2 = :add2,
        entryCity = :city,
        entryCounty = :county,
        entryCountry = :country,
        entryPC = :postcode,
        entryPhone = :phone,
        entryEmail = :email,
        entryURL = :entryurl,
        entryDesc = :entryDesc,
        entryImg = :entryimg,
        entryStar  = :star,
        entryCuststar = :custstar,
        chains = :chains,
        cafe = :cafe,
        fishandchips = :fishandchips,
        indian = :indian,
        itallian = :italian,
        pizzeria = :pizzeria,
        tapas = :tapas,
        tearooms = :tearooms
        WHERE :colname = :entryid";

        $statement = $conn->prepare($sql);

        $statement->bindParam(":tablename", $tablename, PDO::PARAM_STR);

        $statement->bindParam(":entryname", $entryname, PDO::PARAM_STR);
        $statement->bindParam(":add1", $add1, PDO::PARAM_STR);
        $statement->bindParam(":add2", $add2, PDO::PARAM_STR);
        $statement->bindParam(":city", $entrytown, PDO::PARAM_STR);
        $statement->bindParam(":county", $entrycounty, PDO::PARAM_STR);
        $statement->bindParam(":country", $entrycountry, PDO::PARAM_STR);
        $statement->bindParam(":postcode", $entrypostcode, PDO::PARAM_STR);
        $statement->bindParam(":phone", $entryphone, PDO::PARAM_STR);
        $statement->bindParam(":email", $entryemail, PDO::PARAM_STR);
        $statement->bindParam(":entryurl", $entryurl, PDO::PARAM_STR);
        $statement->bindParam(":entryDesc", $entrydesc, PDO::PARAM_STR);
        $statement->bindParam(":entryimg", $entryicon, PDO::PARAM_STR);
        $statement->bindParam(":star", $star, PDO::PARAM_STR);
        $statement->bindParam(":custstar", $custstar, PDO::PARAM_STR);
        $statement->bindParam(":chains", $chains, PDO::PARAM_INT);
        $statement->bindParam(":cafe", $cafe, PDO::PARAM_INT);
        $statement->bindParam(":fishandchips", $fishchips, PDO::PARAM_INT);
        $statement->bindParam(":indian", $indian, PDO::PARAM_INT);
        $statement->bindParam(":italian", $italian, PDO::PARAM_INT);
        $statement->bindParam(":pizzeria", $pizzeria, PDO::PARAM_INT);
        $statement->bindParam(":tapas", $tapas, PDO::PARAM_INT);
        $statement->bindParam(":tearooms", $tearooms, PDO::PARAM_INT);

        $statement->bindParam(":colname", $colname, PDO::PARAM_STR);
        $statement->bindParam(":entryid", $entryid, PDO::PARAM_INT);

        $count = $statement->execute();

我进一步声明了 $conn 变量,它只是我正在制作的练习目录。如果有人能指出我正确的方向,我将不胜感激。

最佳答案

表名和列名不能用 PDO 中的参数替换。 您必须将它们替换为实际名称,当然,如果您愿意,您可以过滤掉不需要的数据,但不能使用准备好的语句。

不起作用:

$sth = $dbh->prepare('SELECT name, colour, calories FROM ?  WHERE calories < ?');

这有效!

$sth = $dbh->prepare('SELECT name, colour, calories FROM fruit WHERE calories < ?');

关于PHP 绑定(bind)变量、无效参数号错误或 PDO 更新语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27362240/

相关文章:

PHP 奇怪的回显行为

php - 多次使用绑定(bind)参数

php - PHP脚本。检查用户是否已经在MySQL数据库中

php - 随机字符串重复?

php - 严格标准:静态函数 model::tableStruct() 不应该是抽象的

mysql:查找不同拼写的单词

mysql - 需要调整mysql查询

mysql - SQL : should I insert another column or parse every single row

php - 如何将2个不同表中的xml数据复制到mysql

php - 显示某些 MySQL 表