因为客户的网络配置,每次连内网是随机分配IP给你,所以经常报Mysql的sql语句出错:
java.sql.SQLException: The user specified as a definer ('ht_release'@'116.226.225.35') does not exist
后来发现是Mysql的Function的安全问题:
执行sql:
ALTER function GETUSERNAME sql security INVOKER;
将SQL SECURITY改成 INVOKER 后,正常运行。
【definer和invoker的解释】
创建存储过程的时候可以指定 SQL SECURITY属性,设置为 DEFINER 或者INVOKER,用来奉告MYSQL在执行存储过程的时候,是以DEFINER用户的权限来执行,还是以调用者的权限来执行。
默认情况下,使用DEFINER方式,此时调用存储过程的用户必须有存储过程的EXECUTE权限,并且DEFINER指定的用户必须是在mysql.user表中存在的用户。
DEFINER模式下,默认DEFINER=CURRENT_USER,在存储过程执行时,mysql会检查DEFINER定义的用户'user_name'@'host_name'的权限;
INVOKER模式下,在存储过程执行时,会检查存储过程调用者的权限。