java调用mysql数据库存储过程报错ERROR 1615 (HY000)问题的解决方法(之一)

假如有一天你突然发现之前一直在调用的存储过程突然有一天出错了,并且错误信息为ERROR 1615 (HY000):Prepared statement needs to be re-prepared,调试其中的sql发现运行也都正常,那么,很有可能问题就出在mysql的两个全局变量(打开表的缓存数量,表定义缓存数量)的设置值过小,而你的数据库表数量较多的情况。

1、打开表的缓存数量(table_open_cache)

2、表定义缓存数量(table_definition_cache)

这2个全局变量可以用一下sql语句查询:

SHOW VARIABLES LIKE '%table_open_cache%';

SHOW VARIABLES LIKE '%table_definition_cache%';

然后使用一下sql语句进行修改,如:

#调整变量值
SET GLOBAL table_open_cache=5000;
SET GLOBAL table_definition_cache=5000;

然后在执行存储过程,结果恢复正常。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值