qt未定义引用 mysql_close

qt未定义引用 mysql_close,第1张

1、在qt的页面里找到Model=newQSqlTableModel(this,db);需要添加"db"。

2、结束时候要关闭db.close()//释放数据库。即可解决引用mysql_close问题。

mysql宕机主要有两个原因:

1.内存被其它进程大量占用,或数据库本身数据量太大导致mysql宕机

2.程序访问mysql后没有执行mysql.close,大量占用资源导致宕机。

群里提出的这个问题主要是mysql5.5以上的,基本上不是mysql宕机。因为5.5以上的数据库会有个链接超时配置。

默认是28800秒也就是8个小时,会断开连接。

解决方案:

1.修改mysql配置。

如果是linux服务器编辑mysql.cnf 执行vi /etc/mysql.cnf

找到[mysqld] 在底下添加

interactive_timeout=28800000

wait_timeout=28800000

多加了三个0 也就是8000个小时。基本就不用考虑连接超时

修改完配置后,记得重启mysql服务。

2.程序方面。

以java程序为例(抱歉只会java)

打开Spring配置文件,修改applicationContext.xml

在datasource bean底下添加

用来指定测试连接所使用的SQL语句。

如果测试发现连接已经close,那么将自动重建连接。

<property name="houseKeepingTestSql">

<value>SELECT 1</value>

</property>

用来指定在使用连接之前要进行测试。

<property name="testBeforeUse">

<value>true</value>

</property>


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5909914.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-08
下一篇 2023-03-08

发表评论

登录后才能评论

评论列表(0条)

保存