问题解决:SpringBoot+mybatis+MySQL环境下,调用存储过程报错

问题场景

使用mybatis调用mysql的存储过程,提示报错。报错描述如下:

Caused by: java.sql.SQLException: User does not have access to metadata required to determine stored procedure parameter types. If rights can not be granted, configure connection with "noAccessToProcedureBodies=true" to have driver generate parameters that represent INOUT strings irregardless of actual parameter types.

本篇博客主要是针对此种情况进行解释说明并提供解决方案。

问题环境

软件版本
MySQL5.7.30

问题原因

当时开发的时候,为了权限控制,专门给项目建了专门的数据库和用户,并将整个数据库赋权给该用户。但是,调用的存储过程是使用root用户创建的,相关的信息是保存在mysql.proc表。而新增用户未将该表的select赋权给该用户,故执行报错。

解决方案

将对应的权限赋权给该用户即可。各位看官可以使用以下SQL:

grant select on mysql.proc to user@host;
flush privileges;

结果

重新调用存储过程,无报错。

总结

问题发生都是有原因的,找到原因再解决,事半功倍。

随缘求赞

如果我的文章对大家产生了帮忙,可以在文章底部点个赞或者收藏;
如果有好的讨论,可以留言;
如果想继续查看我以后的文章,可以点击关注
可以扫描以下二维码,关注我的公众号:枫夜之求索阁,查看我最新的分享!
在这里插入图片描述
拜拜

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

枫夜求索阁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值