Laravel 5 PDO 绑定变量的数量与标记的数量不匹配

Laravel 5 PDO number of bound variables does not match number of tokens

我目前在这方面遇到了问题...

if (Input::has('numenr') and Input::has('table') and Input::has('type') and Input::has('st')) {

    $sql_up = "UPDATE [wds].[dbo].[?] SET [f_nonvint] = ? WHERE [numenr] = '?' AND [f_type] = ?";

    DB::connection('sqlsrv')->update($sql_up, [Input::get('table'), Input::get('st'), Input::get('numenr'), Input::get('type')]);
}

错误输出为:

SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens (SQL: UPDATE [wds].[dbo].[f_files_wines] SET [f_nonvint] = 1 WHERE [numenr] = '091DFF89-EB1B-4B81-9BF0-4AB36F65529E' AND [f_type] = 1)

给出的查询看起来不错,但我不明白这是从哪里来的。

感谢您的帮助! :)

更新:

前面的错误用一个小技巧修复了。问题出在唯一标识符上。我无法在 sql 中添加引号……不知道为什么。 有修复:

if (Input::has('numenr') and Input::has('table') and Input::has('type') and Input::has('st')) {

    $sql_up = "UPDATE [wds].[dbo].[?] SET [f_nonvint] = ? WHERE [numenr] = ? AND [f_type] = ?";

    DB::connection('sqlsrv')->update($sql_up, [Input::get('table'), Input::get('st'), "'".Input::get('numenr')."'", Input::get('type')]);
}

但现在我遇到了一个更奇怪的问题。

SQLSTATE[HY000]: General error: 208 General SQL Server error: Check messages from the SQL Server [208] (severity 16) [(null)] (SQL: UPDATE [wds].[dbo].[t_files_wines] SET [f_nonvint] = 1 WHERE [numenr] = '7AEDE4A0-0109-4729-8AFE-D4A55A0A5893' AND [f_type] = 2)

但事实是,当我将查询复制到SqlServer 时,我没有任何错误! :(

您不能参数化 table 名称本身(您必须将其直接添加到 sql 语句中)。

此行为的原因之一是,SQL 服务器根据传输的 SQL 语句构建其查询计划。但是如果它不知道他应该使用哪个table,它应该如何构建一个查询计划。这就像我想让你告诉我,你需要多长时间从工厂给我带来一些零件,但不要告诉你来自哪个工厂(可能是街对面的小工厂或世界另一半的工厂) .

我使用 DB::statement([MY SQL UPDATE]) 解决了它... 不知道为什么它不工作... 我本可以使用 Eloquent 但我有一个限制条件是要保留更多 SQL.

谢谢大家。