mysql 存储过程表名做参数

我终于弄懂事怎么回事了!!!!!->set@sql=concat('select*from'+$table_name);这里写错了·········应该把‘+’换成‘,’... 我终于弄懂事怎么回事了!!!!!
-> set @sql=concat('select * from '+$table_name); 这里写错了·········应该把‘+’换成‘,’

-> set @sql=concat('select * from ',$table_name); 这样就行了 太坑了
展开
 我来答
百度网友4b68195
2012-11-15 · TA获得超过1520个赞
知道大有可为答主
回答量:1773
采纳率:100%
帮助的人:1721万
展开全部
存储子程序不能包含SQL预处理语句(PREPARE、EXECUTE、DEALLOCATE PREPARE)。隐含意义:不能在存储子程序中使用动态SQL语句(其中,能够以字符串形式构造动态语句,然后执行它们)。从MySQL 5.0.13开始,对于存储程序放宽了该限制,但该限制仍适用于存储函数和触发程序。
更多追问追答
追问
那按照我这个需求应该怎么写啊
追答
写成一个函数试一试。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式