mysql maxpreparedstmtcount_mysql connector Can't create more than max_prepared_stmt_count statements

使用mysql connector的时候,如果报这个错误

Can't create more than max_prepared_stmt_count statements (current value: 16382)

是因为下面的写法有一定问题

调用delete stmt之前出现了错误,直接跳到了catch里面执行,导致stmt没有释放,超出默认值16382。最好是把stmt放到外面,在最后的时候delete。

try

{

sql::PreparedStatement * stmt = con->prepareStatement(sqlstr);

stmt->setInt(1, id1);

stmt->setInt(2, id2);

stmt->execute();

delete stmt;

}

catch (sql::SQLException & e)

{

bsqlcon = false;

Log_Text_Format(LOGLEVEL_ERROR, "Err: SQLException in %s %s %d ERR[%s] ErrCode[%d] SQLState[%s] sql[%s]", __FILE__, __FUNCTION__, __LINE__, e.what(), e.getErrorCode(), e.getSQLState().c_str(), sqlstr.c_str());

}

可以通过下面的语句查看目前申请了几个,使用了几个,释放了几个,正常情况申请的和释放的应该是很接近在几十或是上百个以内,并且固定不变不会逐渐增加。如果程序直接关闭,申请释放的这个值是不会改变的,还是维持最后一次的记录,这一点需要注意。

show global status like 'com_stmt%';

Com_stmt_execute    563281

Com_stmt_close    563280

Com_stmt_fetch    0

Com_stmt_prepare    563359

Com_stmt_reset    0

Com_stmt_send_long_data    0

Com_stmt_reprepare    0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值