我写了这个查询,它有错误,有什么问题吗?
prepare test from
'select * from ?';问题出在哪里?
它的正确形式是什么?
发布于 2011-03-19 04:36:13
你不能把占位符放在你喜欢的任何地方。参数占位符只能出现在语句中通常需要表达式的位置。特别是,不能使用参数占位符参数化标识符或整个语句结构。这就是为什么你的尝试失败了。
在Roland Bouman's blog -> MySQL 5: Prepared statement syntax and Dynamic SQL中可以找到更多关于MYSQL中的预准备语句和动态SQL的有用信息。
如果您的目标用途类似于:
prepare test
from
'select * from ?' ;
set @myt := 'myTable' ;
execute test
using @myt ;它根本不会起作用。但您可以使用以下命令绕过它:
set @myt := 'myTable'
set @qtext := concat('select * from ',@myt) ;
prepare test
from @qtext ;
execute test ;发布于 2011-03-19 03:45:07
我从来没有尝试过将表名作为变量。我不确定这是不是允许的。尝试以下操作:
PREPARE test FROM "SELECT * FROM table_name WHERE column = ?";这是一种暗箭,因为您没有提供错误消息。
https://stackoverflow.com/questions/5356983
复制相似问题