为什么 Mybatis sql 表名用参数传递进来的时候,只能使用 ${} ,不能用#{}? 5

 我来答
中中
2019-11-15
知道答主
回答量:35
采纳率:0%
帮助的人:10.4万
展开全部

因为使用#{},mybatis使用connection.prepareStatement("select * from ?"),把表名作为参数提交给数据库,而数据库不支持这种方式。

而使用${},mybatis是字符串拼接,也就是connection.prepareStatement("select * from tabName"),这是正常写法。

所以本质上是数据库不支持。

我把这个问题记录到我的小站匠艺软件

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式