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

Spring Boot整合Thymeleaf

Java解决执行mvn spring-boot:run报错jar时出错; zip file is empty

Spring Boot中自动执行sql脚本

spring boot 配置启动后执行sql, 中文乱码

Spring Boot连接MySQL报错“Internal Server Error”的解决办法