mysql 1615_解决MySQL报错:ERROR 1615 (HY000) : Prepared statement needs to be re-prepared

MySQL执行一个存储过程,报错如下:ERROR 1615 (HY000) at line 406 in file: 'process.sql': Prepared statement needs to be re-prepared

这个问题解决设计到以下两个变量:table_open_cache: 表高速缓存的大小

table_definition_cache:表定义信息缓存

一、问题定位

查看Opened_tables的值:mysql> show global status like 'open%tables%';

+---------------+-------+

| Variable_name | Value |

+---------------+-------+

| Open_tables |  409 |

| Opened_tables | 6433516 |

+---------------+-------+

2 rows in set (0.01 sec)

Opened_tables数值非常大,说明cache太小,导致要频繁地open table。

二、问题解决

查看table_open_cachemysql> show variables like '%table_open_cache%';

+------------------+-------+

| Variable_name | Value |

+------------------+-------+

| table_open_cache | 64|

+------------------+-------+

默认是64,有些文章建议,设置:table_open_cache=max_connections* 查询同时用到的表数

修改如下:mysql> set global table_open_cache=16384;

mysql> set global table_definition_cache=16384;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值