本文借鉴了网上的很多博客,在此不再声明 总结 1.增加 MySQL 的 wait_timeout 属性的值(不推荐) mysql5之前的版本,可以在jdbc连接的url中加入:autoReconnect = true 设置mysql5中wait_timeout 在linux中最大为365,wait_timeout=31536000 在window中最大为24天,以window为例: 这个方法并不推荐,原因: MySQL服务器所支撑的最大连接数是有限的,因为每一个连接.第一个表打开的操作都要消耗服…
转自:http://blog.csdn.net/wangfayinn/article/details/24623575 c3p0数据库连接池mysql8小时 目录(?)[-] 基本问题解决 项目环境 错误描述 报错日志 原因分析 解决方案解决这个问题的办法有三种推荐第二种 增加 MySQL 的 wait_timeout 属性的值 减少连接池内连接的生存周期 定期使用连接池内的连接 知识扩展 C3P0 使用DBCP连接池时出现MySql 8小时断开连接的解决方法 回顾 本文提供了对c3p0与DBC…
最近做的项目用的mysql数据库,前天挂在服务器上,昨天早晨上班一来,同事就说API数据接口访问不了了,我马上mstsc登陆服务器看,报错了.马上重启tomcat,结果还能正常运行,当时没管,今天过来又出现相同的问题,错误代码网上一查,原来是MySql8小时的问题. MySql8小时问题: 小时后,MySQL 就会断开该连接,而 c3p0 连接池则以为该被断开的连接依然有效.在这种情况下,如果客户端代码向 c3p0 连接池请求连接的话,连接池就会把已经失效的连接返回给客户端,客户端在使用该失效连…
本文提供了对c3p0与DBCP连接池连接MySql数据库时. 8小时内无请求自己主动断开连接的解决方式.首先介绍一下我在项目(c3p0连接池)中遇到的问题,后面还提供了使用DBCP连接池的解决方式. 基本问题解决 项目环境: Java Web项目框架为Spring MVC+JPA,使用c3p0连接池,公布环境为Tomcat 7 错误描写叙述: 项目执行一段时间(大概几个小时)之后訪问时会出现第一次訪问报错,再次訪问正常的现象.且多次出现此问题. 报错日志: org.springframework…
今天遇到了一个很坑人的问题,从昨晚一直搞到今天早上,终于发现了,先整理下: [背景]:利用hibernate自动给mysql创建一个表,然后为表里面添加一行记录,非常的简单(当然其中还涉及到spring框架的问题,其实就是用spring接管了数据源和会化工厂的一些配置而已) 好了,问题开始,一下是数据源和会话工厂的一些配置信息: <!--配置数据源 --> <bean id="dataSource" class="org.apache.commons.dbc…
MySQL 取得小时分钟部分 SELECT `CpParkID` , DATE_FORMAT( `UPDATE_TIME` , '%H:%i' )FROM `cp_park`WHERE HOUR( `UPDATE_TIME` ) = '08'AND MINUTE( `UPDATE_TIME` ) = '59' 结果CpParkID DATE_FORMAT(`UPDATE_TIME`,'%H:%i') 4428 08:59 4429 08:59 4430 08:59 4431 08:59 相同数据…
mysql服务突然丢失解决方案 今天系统从win7更新到win10之后,mysql突然没了,使用navicat连接提示如下: 看到这个,以为自己的mysql服务没启动,于是打开服务找mysql服务,发现并没有mysql服务,于是在网上寻找mysql服务安装办法,解决方案如下: 打开mysql的安装目录 在安装目录下的bin目录中打开命令提示符并执行命令 mysqld --install 上图是在powershell中执行" mysqld --install "命令的截图,通过以上截图可…
Hibernate懒加载的两种解决方案: 1.Hibernate.initialize(代理对象) 2.在*.hbm.xml映射文件中添加lazy="false"属性 3.使用opensessioninview(彻底)…
经常有用户过来咨询说自己的mysql服务器忘记密码了怎么办,为了更好的解决大家的困扰,本文特归档整理了windows和linux系统下,mysql忘记密码的解决方案.本文内容是我亲测实用,当然过程中踩过的坑我也会在本文中一并分享交流.废话不多说,上菜- Windows篇 演示环境: 服务器:windows2003 64位企业版 mysql版本:5.6.17 操作步骤: 1. 关闭mysql服务. 以管理员身份登录到您的服务器系统,如果服务器上的Mysql正在运行,则先停止MySQL服务.对于Wi…
远程客户端连接MysqL数据库太慢解决方案局域网客户端访问mysql 连接慢问题解决. cd /etc/mysql vi my.conf [mysqld] skip-name-resolve 此选项禁用了DNS解析,连接速度会快很多不过,这样的话就不能在MySQL的授权表中使用 主机名了而只能用ip格式.…
忘记本地MySQL数据库密码,解决方案,分以下10个步骤: 参考链接:                  https://blog.csdn.net/weidong_y/article/details/80493743:                  https://blog.csdn.net/anzhen0429/article/details/78296814: 数据库版本:5.7.21 平台:win7 1.打开cmd窗口,进入 MySQL的安装目录. 2.停止MySQL的服务.已经停止…
mysql主从复制报错解决方案 我先制造个错误 在slave删除个info3字段 然后在master 在info3插入数据 报错如下<pre> Last_SQL_Errno: 1054 Last_SQL_Error: Error 'Unknown column 'info3' in 'field list'' on query. Default database: 'test1'. Query: 'INSERT INTO `test1`.`wef` (`id`, `info1`, `info2…
在生产环境中使用了 自带的连接池 结果 遇到 mysql8小时问题 然后 采用了 c3p0 连接池 hibernate 版本 4.3.6 c3p0版本 0.9.5-pre10 ps:hibernate-c3p0 4.3.6 默认引用的 0.9.2.1的c3p0有点问题. 如果不想使用 0.9.5以上的 c3p0池 需要在 hibernate config 里面添加 <property name="hibernate.c3p0.preferredTestQuery">sele…
之前在使用SSH开发项目的时候遇到了一个很奇怪的问题,部署到服务器上,运行一段时间后系统就崩溃了. 出现错误:org.hibernate.exception.JDBCConnectionException: could not execute query 在后在百度上查了下资料发现了问题所在,原来这个是传说中的8小时问题— —. 一.什么是8小时问题? Mysql服务器默认的“wait_timeout”是8小时,也就是说一个connection空闲超过8个小时,Mysql将自动断开该 conne…
HTTP Status 500 - Request processing failed; nested exception is org.springframework.dao.TransientDataAccessResourceException: type Exception report message Request processing failed; nested exception is org.springframework.dao.TransientDataAccessRes…
1.使用 schemaExport(hibernate5.2.3)创建Mysql表 @Test public void testSchemaExport() { ServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder().configure().build(); Metadata metadata = new MetadataSources(serviceRegistry).buildMetadata(); Sch…
查了一下发现应用程序和mysql数据库建立连接,如果超过8小时应用程序不去访问数据库,数据库就断掉连接 .这时再次访问就会抛出异常. 关于mysql自动断开的问题研究结果如下, 1.c3p0.HikariCP等连接池配置. 2.在自己的程序中插入定时访问数据库的方法,比如使用Timer,Quartz或者spring中简易Quartz. 3.在mysql中有相关参数设定,当数据库连接空闲一定时间后,服务器就会断开等待超时的连接:相关参数 mysql> show variables like '%t…
1. 使用过程 2. 背景 3. 遇到问题 3.1 不指定Hibernate数据库方言,默认SQL生成方式 3.2 抛出异常Hibernate加入了@Transactional事务不会回滚 3.3 Hibernate使用Spring Test测试加入了@Transactional事务无论如何数据库插入不成功 3.4 Hibernate在使用MyISAM引擎也可以回滚? 3.5 Hibernate在使用生成策略是IDENTITY不能回滚事务,AUTO可以 3.6 使用MyISAM引擎下@Contr…
MySQL> show variables like '%timeout%'; +--------------------------+-------+ | Variable_name            | Value | +--------------------------+-------+ | connect_timeout           | 5     | | delayed_insert_timeout   | 300   | | innodb_lock_wait_timeo…
hibernate自动建表,mysql高版本不支持 type=InnoDB 中的type关键字. 应该使用engine关键字 而非type 所以需要在hibernate.cfg.xml中配置方言.否则在create table语句中会抛sql语法错误异常. <property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property> Hibernate: creat…
假设你的数据库是mysql,如果数据源配置不当,将可能发生经典的"8小时问题".原因是mysql在默认情况下,如果发现一个连接的空闲时间超过8小时,将会在数据库端自动关闭这个连接.而数据源并不知道这个连接已经关闭了,当它将这个无用的连接返回给某个dao时,dao就会报无法获取connection异常.     如果采用dbcp的默认配置,由于testOnBorrow属性的默认值是true,数据源在将连接交给dao前,会事先检测这个连接是否是好的,如果连接有问题(在数据库端被关闭),则会…
在java中new Date()输出的时间是没错的,插入到mysql后少了14个小时,原因是新版jdbc驱动的时区设置问题. 在jdbc连接url最后加上serverTimezone=GMT%2B8即可,注意是%2B8…
使用hibernate连接mysql数据库 1:项目搭建好之后,在lib包中添加必要的jar包,和mysql数据库驱动jar包: jar包可以在hibernate的下载包(hibernate3.3.2.GA)中找到,这里所需要的jar包是: hibernate3.jar,lib/required目录下的所有jar包; 连接数据库所需要的jar包:mysql-connector-java-5.1.7-bin.jar; 如图: 2:jar包引入后编写实体类及映射文件: 实体类是xx.java文件;映…
1. 引入dbcp (选择1.4) Java代码   com.alibaba.external jakarta.commons.dbcp 1.4 2. dbcp的基本配置 相关配置说明: initialSize :连接池启动时创建的初始化连接数量(默认值为0) maxActive :连接池中可同时连接的最大的连接数(默认值为8,调整为20,高峰单机器在20并发左右,自己根据应用场景定) maxIdle:连接池中最大的空闲的连接数,超过的空闲连接将被释放,如果设置为负数表示不限制(默认为8个,ma…
1.打开MySQL配置文件 2.添加 interactive_timeout=31536000wait_timeout=31536000 3.重新启动服务 打开MySQL命令行界面查看设置是否成功…
org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.springframework.dao.DataAccessResourceFailureException: SqlMapClient operation; SQL []; --- The error occurred in ibatis/comm/comm-Sql-Map.xml. --…
1.12小时显示 SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss"); String time = dateFormat.format(new Date()).toString(); System.out.println(time); 2.24小时显示 SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH…
1.我们通过DB与数据库建立连接 2.建立web工程,构建Hibernate框架 3.通过table生成实体类…
最近自己做测试的时候,发现中文入库成?号了,不由得想到是否某处编码设置问题. 1.检查数据库是否为utf8 2.检查配置文件,数据库链接地址是否指定编码,经检查本地配置文件 jdbc.url=jdbc:mysql://localhost:3306/WeChat?useUnicode=true&characterEncoding=utf8 没问题... 3.检查mysql配置文件my.ini,在[mysql]以及[mysqld]下面查询default-character-set = utf8是否设…
1.1 主从复制基础概念 在了解主从复制之前必须要了解的就是数据库的二进制日志(binlog),主从复制架构大多基于二进制日志进行,二进制日志相关信息参考:http://www.cnblogs.com/clsn/p/8087678.html#_label6 1.1.1 二进制日志管理说明 二进制日志在哪?如何设置位置和命名? 在my.cnf文件中使用 log-bin = 指定:命名规则为 mysql-bin.000000 (后为6位数字) 二进制日志位置 mysql> show variable…