spring boot 执行my sql 报错The user specified as a definer (‘‘@‘‘) does not exist,解决方案
Posted yqj234
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了spring boot 执行my sql 报错The user specified as a definer (‘‘@‘‘) does not exist,解决方案相关的知识,希望对你有一定的参考价值。
1.问题描述
Hibernate: select f_get_purchase_order_no()
[2m2021-08-15 19:26:45.087[0;39m [33m WARN[0;39m [35m36920[0;39m [2m---[0;39m [2m[nio-8080-exec-9][0;39m [36mo.h.engine.jdbc.spi.SqlExceptionHelper [0;39m [2m:[0;39m SQL Error: 1449, SQLState: HY000
[2m2021-08-15 19:26:45.087[0;39m [31mERROR[0;39m [35m36920[0;39m [2m---[0;39m [2m[nio-8080-exec-9][0;39m [36mo.h.engine.jdbc.spi.SqlExceptionHelper [0;39m [2m:[0;39m (conn=243) (conn=243) (conn=243) The user specified as a definer (''@'') does not exist
2 解决方案
2.1 原因分析
因为创建视图使用的是root@%用户(目前已经不存在),然后登录用户使用的是root@localhost用户,导致mysql认为现在的用户无权限访问该视图,解决方法就是在当前用户下重建该视图。
2.2 修改创建人员,选择相应登陆帐号
2.3 定义SQL安全级别为Invoker
以上是关于spring boot 执行my sql 报错The user specified as a definer (‘‘@‘‘) does not exist,解决方案的主要内容,如果未能解决你的问题,请参考以下文章
Spring boot 打包为war包报错:提示缺少web.xml