问题解决: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.
本篇博客主要是针对此种情况进行解释说明并提供解决方案。
问题环境
软件 | 版本 |
---|---|
MySQL | 5.7.30 |
问题原因
当时开发的时候,为了权限控制,专门给项目建了专门的数据库和用户,并将整个数据库赋权给该用户。但是,调用的存储过程是使用root用户创建的,相关的信息是保存在mysql.proc
表。而新增用户未将该表的select
赋权给该用户,故执行报错。
解决方案
将对应的权限赋权给该用户即可。各位看官可以使用以下SQL:
grant select on mysql.proc to user@host;
flush privileges;
结果
重新调用存储过程,无报错。
总结
问题发生都是有原因的,找到原因再解决,事半功倍。
随缘求赞
如果我的文章对大家产生了帮忙,可以在文章底部点个赞或者收藏;
如果有好的讨论,可以留言;
如果想继续查看我以后的文章,可以点击关注
可以扫描以下二维码,关注我的公众号:枫夜之求索阁,查看我最新的分享!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程