- 浏览: 96263 次
- 来自: 北京
最新评论
-
jizpp:
HI,你这个问题最后有解决么?能说明下么,最近正碰到这个问题。 ...
spring+hibernate配置c3p0无法释放数据库连接 -
zhangskills:
自己写的方法?
jsp参数过滤防注入的解决方法 -
zhangskills:
split(inj_str,"|"); ...
jsp参数过滤防注入的解决方法 -
Alrale:
对输入信息先分词,然后依次存入map(信息为key,出现次数为 ...
一道关于热门关键词的面试题 -
dust_dn:
弱弱的问下该怎么做啊。。。。
一道关于热门关键词的面试题
弄了3天,还是没有搞定。
配置:
winxp+tomcat5.0.28+hibernate3.1+spring1.2.6+struts1.0+mysql5.0.17,做了一个小blog。没有配置连接池时,运转良好。用c3p0配置后,每次都会出现3或者5个新连接。然后发现数据库连接不能释放。出现很多sleep连接。直到全部连接占满。
出现:错误表现:
数据库的表现是:
类似的问题,但没有都没有很好的解决方法。
c3p0.properties的配置是:
BlogDaoimpl的代码是:
请各位高手帮我看看,到底是什么原因(连接池问题,还是代码问题(不用连接池运转良好)导致数据库sleep连接不能释放。谢谢!
这里有一个大大写的c3p0的详细配置说明,http://msq.iteye.com/blog/60387,上面对各个属性的作用说的比较详细,有几个性能相关的属性你试一下,希望对你有些帮助。
c3p0详细的代码我也只是看过一点,暂时没有什么好的建议,有时间的话研究一下,再探讨。
可以正常使用的,但是正在执行的事务会被终止,并抛出一个异常……
有可能是这段代码的问题。这种直接取出session然后执行的代码在关闭连接方面好像有问题。你把你的代码替换成getHibernateTemplate().XXX()这样,使用Template的方法来实现。看看连接数是否还会有问题。(你原本的连接池配置没有多大问题)
我最近也有过这种问题,最开始是
出现跟你一样的问题,后来换成了
问题解决。
最后附上我的连接池配置
谢谢,不过还是不行。谢谢抛出。
不知道c3p0是不是在中间。spring的位置在那里?datasource的位置在那里?
hibernate--> c3p0 -->jdbc
spring --> hibernate -->c3p0 -->jdbc?
写一个测试用的页面,每秒刷新N次。。。
之后再看。。。内存。。。
如果还长。。。那就是缓存的问题了。。。
如果不长。。。再看代码也来的急。。。。代码想要看一遍会死人的。
配置:
winxp+tomcat5.0.28+hibernate3.1+spring1.2.6+struts1.0+mysql5.0.17,做了一个小blog。没有配置连接池时,运转良好。用c3p0配置后,每次都会出现3或者5个新连接。然后发现数据库连接不能释放。出现很多sleep连接。直到全部连接占满。
出现:错误表现:
javax.servlet.ServletException: Hibernate operation: Cannot open connection; uncategorized SQLException for SQL [???]; SQL state [null]; error code [0]; Connections could not be acquired from the underlying database!; nested exception is java.sql.SQLException: Connections could not be acquired from the underlying database
数据库的表现是:
类似的问题,但没有都没有很好的解决方法。
引用
06-21-2006 spring论坛一问题。
http://forum.springframework.org/showthread.php?t=26124
JavaEye
求助,Spring+Hibernate连接池无法释放问题,贴出详细代码
http://www.iteye.com/topic/32378
下面是applicationContext.xml的配置:
http://forum.springframework.org/showthread.php?t=26124
JavaEye
求助,Spring+Hibernate连接池无法释放问题,贴出详细代码
http://www.iteye.com/topic/32378
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd"> <beans> <!-- for properties files --> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:c3p0.properties</value> </list> </property> </bean> <!-- for dataSource --> <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> <property name="driverClass" value="${jdbc.driver}" /> <property name="jdbcUrl" value="${jdbc.url}" /> <property name="properties"> <props> <prop key="c3p0.minPoolSize">${hibernate.c3p0.minPoolSize}</prop> <prop key="hc3p0.maxPoolSize">${hibernate.c3p0.maxPoolSize}</prop> <prop key="hc3p0.timeout">${hibernate.c3p0.timeout}</prop> <prop key="c3p0.max_statement">${hibernate.c3p0.max_statement}</prop> <prop key="user">${jdbc.username}</prop> <prop key="password">${jdbc.password}</prop> <prop key="c3p0.testConnectionOnCheckout">true</prop> </props> </property> </bean> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource"> <ref bean="dataSource" /> </property> <property name="mappingResources"> <list> <value>com/voff/hibernate/Blog.hbm.xml</value> </list> </property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect"> org.hibernate.dialect.MySQLDialect </prop> <prop key="hibernate.show_sql"> true </prop> <prop key="hibernate.connection.provider_class"> org.hibernate.connection.C3P0ConnectionProvider </prop> </props> </property> </bean> <!-- transactionManager --> <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory"> <ref bean="sessionFactory"/> </property> </bean> <bean id="BlogDao" class="com.voff.dao.BlogDaoimpl"> <property name="sessionFactory"> <ref bean="sessionFactory"/> </property> </bean> <!-- spring dao proxy --> <bean id="BlogDaoProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"> <property name="transactionManager"> <ref bean="transactionManager"/> </property> <property name="proxyInterfaces"> <list> <value>com.voff.dao.BlogDao</value> </list> </property> <property name="target"> <ref bean="BlogDao"/> </property> <property name="transactionAttributes"> <props> <prop key="insert">PROPAGATION_REQUIRED</prop> <prop key="save*">PROPAGATION_REQUIRED</prop> <prop key="update*">PROPAGATION_REQUIRED</prop> <prop key="find*">PROPAGATION_REQUIRED</prop> <prop key="*">PROPAGATION_REQUIRED,readOnly</prop> </props> </property> </bean> </beans>
c3p0.properties的配置是:
jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost/spring?useUnicode=true&characterEncoding=UTF-8 jdbc.username=root jdbc.password= hibernate.c3p0.minPoolSize=5 hibernate.c3p0.maxPoolSize=20 hibernate.c3p0.timeout=100 hibernate.c3p0.max_statement=50
BlogDaoimpl的代码是:
package com.voff.dao; import java.util.ArrayList; import java.util.List; import org.hibernate.Query; import org.hibernate.Session; import org.springframework.orm.hibernate3.support.HibernateDaoSupport; import com.voff.hibernate.Blog; public class BlogDaoimpl extends HibernateDaoSupport implements BlogDao{ public void addblog(Blog blog) { getHibernateTemplate().save(blog); } public void delblog(int id) { Object blog=getHibernateTemplate().load(Blog.class,id); getHibernateTemplate().delete(blog); } public void updateblog(Blog blog) { getHibernateTemplate().update(blog); } public Blog getblog(int id){ return (Blog) getHibernateTemplate().get(Blog.class,id); } public int Totallimitblog(int caid,String bauthor){ String sql = "from Blog where cateid='"+caid+"' and bauthor ='"+bauthor+"'"; List total = getHibernateTemplate().find(sql); return total.size(); } public ArrayList showblog(int firstRow,int maxRow,int caid,String bauthor){ List list=new ArrayList(); Session session = getHibernateTemplate().getSessionFactory().openSession(); Query query =session.createQuery("from Blog where cateid='"+caid+"' and bauthor ='"+bauthor+"' order by blogid desc"); query.setFirstResult(firstRow); query.setMaxResults(maxRow); list=query.list(); session.flush(); session.close(); return (ArrayList) list; } }
请各位高手帮我看看,到底是什么原因(连接池问题,还是代码问题(不用连接池运转良好)导致数据库sleep连接不能释放。谢谢!
评论
22 楼
jizpp
2014-06-22
HI,你这个问题最后有解决么?能说明下么,最近正碰到这个问题。
21 楼
antonyup_2006
2007-10-19
看了有启发!
20 楼
tom.duan
2007-09-18
zhaosong 写道
谢谢tom.duan
检测连接是否可用,是直接发送一个简单数据库请求来检测的,还是有什么更好的方法吗?
另外有推荐的连接池的 ---优秀的数据库连接分配机制--- 吗?
我看了一下c3p0的代码,因为层次太复杂,时间比较少所以没看出具体算法,希望能同过少量代码反映优秀连接分配算法的。不胜感激!!!(以前写的一个不太理想)
检测连接是否可用,是直接发送一个简单数据库请求来检测的,还是有什么更好的方法吗?
另外有推荐的连接池的 ---优秀的数据库连接分配机制--- 吗?
我看了一下c3p0的代码,因为层次太复杂,时间比较少所以没看出具体算法,希望能同过少量代码反映优秀连接分配算法的。不胜感激!!!(以前写的一个不太理想)
这里有一个大大写的c3p0的详细配置说明,http://msq.iteye.com/blog/60387,上面对各个属性的作用说的比较详细,有几个性能相关的属性你试一下,希望对你有些帮助。
c3p0详细的代码我也只是看过一点,暂时没有什么好的建议,有时间的话研究一下,再探讨。
19 楼
zhaosong
2007-09-14
谢谢tom.duan
检测连接是否可用,是直接发送一个简单数据库请求来检测的,还是有什么更好的方法吗?
另外有推荐的连接池的 ---优秀的数据库连接分配机制--- 吗?
我看了一下c3p0的代码,因为层次太复杂,时间比较少所以没看出具体算法,希望能同过少量代码反映优秀连接分配算法的。不胜感激!!!(以前写的一个不太理想)
检测连接是否可用,是直接发送一个简单数据库请求来检测的,还是有什么更好的方法吗?
另外有推荐的连接池的 ---优秀的数据库连接分配机制--- 吗?
我看了一下c3p0的代码,因为层次太复杂,时间比较少所以没看出具体算法,希望能同过少量代码反映优秀连接分配算法的。不胜感激!!!(以前写的一个不太理想)
18 楼
tom.duan
2007-09-13
zhaosong 写道
问一下用过c3p0的同志:
这个c3p0连接池在运行中,如果和数据库的网络连接断开过几分钟恢复连接,这个连接池是否还可以正常工作。如果可以正常工作,那么多长时间后就不能正常运行了,可以设定吗?
这个c3p0连接池在运行中,如果和数据库的网络连接断开过几分钟恢复连接,这个连接池是否还可以正常工作。如果可以正常工作,那么多长时间后就不能正常运行了,可以设定吗?
可以正常使用的,但是正在执行的事务会被终止,并抛出一个异常……
17 楼
zhaosong
2007-09-12
问一下用过c3p0的同志:
这个c3p0连接池在运行中,如果和数据库的网络连接断开过几分钟恢复连接,这个连接池是否还可以正常工作。如果可以正常工作,那么多长时间后就不能正常运行了,可以设定吗?
这个c3p0连接池在运行中,如果和数据库的网络连接断开过几分钟恢复连接,这个连接池是否还可以正常工作。如果可以正常工作,那么多长时间后就不能正常运行了,可以设定吗?
16 楼
tom.duan
2007-09-12
<property name="maxStatements">100</property> ,这个属性有什么用?直接去掉好了……
然后尝试一下把<prop key="hibernate.c3p0.idle_test_period">120</prop>属性设置小一些,例如30,让更短的时间检查空连接,以便释放。
<prop key="hibernate.c3p0.acquire_increment">2</prop>,值可否设置大一些?
然后尝试一下把<prop key="hibernate.c3p0.idle_test_period">120</prop>属性设置小一些,例如30,让更短的时间检查空连接,以便释放。
<prop key="hibernate.c3p0.acquire_increment">2</prop>,值可否设置大一些?
15 楼
香克斯
2007-09-10
# public ArrayList showblog(int firstRow,int maxRow,int caid,String bauthor){ # List list=new ArrayList(); # # Session session = getHibernateTemplate().getSessionFactory().openSession(); # Query query =session.createQuery("from Blog where cateid='"+caid+"' and bauthor ='"+bauthor+"' order by blogid desc"); # query.setFirstResult(firstRow); # query.setMaxResults(maxRow); # list=query.list(); # session.flush(); # session.close(); # return (ArrayList) list; # } #
有可能是这段代码的问题。这种直接取出session然后执行的代码在关闭连接方面好像有问题。你把你的代码替换成getHibernateTemplate().XXX()这样,使用Template的方法来实现。看看连接数是否还会有问题。(你原本的连接池配置没有多大问题)
我最近也有过这种问题,最开始是
Criteria criteria = getSession().createCriteria(getPersistentClass()) .add(Example.create(exampleInstance)); try { Map<Object, Object> propertyMap; propertyMap = BeanUtils.describe(exampleInstance); if (propertyMap.containsKey("id") && propertyMap.get("id") != null) { criteria.add(Expression.idEq(new Integer((String)propertyMap.get("id")))); } } catch (Exception e) { logger.error("describe bean Exception : ", e); } int totalCount = (Integer) criteria.setProjection( Projections.rowCount()).uniqueResult(); criteria.setProjection(null); if (totalCount < 1) { return new Page(); } int startIndex = Page.getStartOfPage(pageNo, pageSize); List list = criteria.setFirstResult(startIndex).setMaxResults(pageSize) .list();
出现跟你一样的问题,后来换成了
DetachedCriteria criteria = DetachedCriteria.forClass( getPersistentClass()).add(Example.create(exampleInstance)); try { Map<Object, Object> propertyMap; propertyMap = BeanUtils.describe(exampleInstance); if (propertyMap.containsKey("id") && propertyMap.get("id") != null) { criteria.add(Expression.idEq(new Integer((String) propertyMap .get("id")))); } } catch (Exception e) { logger.error("describe bean Exception : ", e); } int totalCount = (Integer) getHibernateTemplate().findByCriteria( criteria.setProjection(Projections.rowCount())).get(0); criteria.setProjection(null); if (totalCount < 1) { return new Page(); } int startIndex = Page.getStartOfPage(pageNo, pageSize); List list = getHibernateTemplate().findByCriteria(criteria,startIndex,pageSize);
问题解决。
最后附上我的连接池配置
<bean id="DataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close"> <property name="driverClass"> <value>${jdbc.driver}</value> </property> <property name="jdbcUrl"> <value>${jdbc.url}</value> </property> <property name="user"> <value>${jdbc.username}</value> </property> <property name="password"> <value>${jdbc.password}</value> </property> <property name="initialPoolSize"> <value>${c3p0.initialPoolSize}</value> </property> <property name="minPoolSize"> <value>${c3p0.minPoolSize}</value> </property> <property name="maxPoolSize"> <value>${c3p0.maxPoolSize}</value> </property> <property name="acquireIncrement"> <value>${c3p0.acquireIncrement}</value> </property> <property name="maxIdleTime"> <value>${c3p0.maxIdleTime}</value> </property> <property name="idleConnectionTestPeriod"> <value>${c3p0.idleConnectionTestPeriod}</value> </property> <property name="maxStatements"> <value>${c3p0.maxStatements}</value> </property> <property name="checkoutTimeout"> <value>${c3p0.checkoutTimeout}</value> </property> <property name="acquireRetryAttempts"> <value>${c3p0.acquireRetryAttempts}</value> </property> <property name="breakAfterAcquireFailure"> <value>${c3p0.breakAfterAcquireFailure}</value> </property> <property name="autoCommitOnClose"> <value>${c3p0.autoCommitOnClose}</value> </property> <property name="testConnectionOnCheckout"> <value>${c3p0.testConnectionOnCheckout}</value> </property> </bean> <bean id="sessionFactory" name="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource"> <ref bean="DataSource" /> </property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect"> ${hibernate.dialect} </prop> <prop key="hibernate.show_sql">${hibernate.show_sql}</prop> <prop key="hibernate.autoReconnect">${hibernate.autoReconnect}</prop> <prop key="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</prop> <prop key="hibernate.cache.use_query_cache">true</prop> <prop key="hibernate.jdbc.batch_size">${hibernate.jdbc.batch_size}</prop> </props> </property> <property name="mappingResources"> <list> <value>Role.hbm.xml</value> </list> </property> </bean>
14 楼
hamburg
2007-09-04
个人认为c3p0本身可能存在一定的问题,
我的应用有时候会抛出一个
java.sql.SQLException: An attempt by a client to checkout a Connection has timed out.
我的应用有时候会抛出一个
java.sql.SQLException: An attempt by a client to checkout a Connection has timed out.
13 楼
wuyingsong
2007-07-04
没有问题
12 楼
wuyingsong
2007-07-04
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
<property name="driverClass">
<value>com.mysql.jdbc.Driver</value>
</property>
<property name="jdbcUrl">
<value>jdbc:mysql://localhost/auction</value>
</property>
<property name="user">
<value>root</value>
</property>
<property name="password">
<value>123456</value>
</property>
<property name="maxPoolSize">
<value>40</value>
</property>
<property name="minPoolSize">
<value>1</value>
</property>
<property name="initialPoolSize">
<value>1</value>
</property>
<property name="maxIdleTime">
<value>20</value>
</property>
</bean>
<!--定义了Hibernate的SessionFactory -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="dataSource"/>
</property>
<property name="mappingResources">
<list>
<value>AuctionUser.hbm.xml</value>
<value>Bid.hbm.xml</value>
<value>Item.hbm.xml</value>
<value>Kind.hbm.xml</value>
<value>State.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
<prop key="show_sql">true</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.jdbc.batch_size">20</prop>
</props>
</property>
</bean>
<property name="driverClass">
<value>com.mysql.jdbc.Driver</value>
</property>
<property name="jdbcUrl">
<value>jdbc:mysql://localhost/auction</value>
</property>
<property name="user">
<value>root</value>
</property>
<property name="password">
<value>123456</value>
</property>
<property name="maxPoolSize">
<value>40</value>
</property>
<property name="minPoolSize">
<value>1</value>
</property>
<property name="initialPoolSize">
<value>1</value>
</property>
<property name="maxIdleTime">
<value>20</value>
</property>
</bean>
<!--定义了Hibernate的SessionFactory -->
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="dataSource"/>
</property>
<property name="mappingResources">
<list>
<value>AuctionUser.hbm.xml</value>
<value>Bid.hbm.xml</value>
<value>Item.hbm.xml</value>
<value>Kind.hbm.xml</value>
<value>State.hbm.xml</value>
</list>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
<prop key="show_sql">true</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.jdbc.batch_size">20</prop>
</props>
</property>
</bean>
11 楼
voff12
2007-06-07
tonyyl 写道
hibernate.connection.provider_class=C3p0ConnectionProvider,这样就该行了
谢谢,不过还是不行。谢谢抛出。
不知道c3p0是不是在中间。spring的位置在那里?datasource的位置在那里?
hibernate--> c3p0 -->jdbc
spring --> hibernate -->c3p0 -->jdbc?
10 楼
抛出异常的爱
2007-06-07
voff12 写道
还是得看源代码,以求彻底解决此问题。
如果c3p0起作用的话:
tomcat起动后,打开浏览页后,可以看到设定的5个最小5个连接数(MySQL Adminstator观察)出现。
而且可以用Jprofire检测到c3p0包的使用情况:
。
当用户增加多时,数据库最大的连接数增到20后,连接数不再增加。
如果c3p0起作用的话:
tomcat起动后,打开浏览页后,可以看到设定的5个最小5个连接数(MySQL Adminstator观察)出现。
而且可以用Jprofire检测到c3p0包的使用情况:
。
当用户增加多时,数据库最大的连接数增到20后,连接数不再增加。
写一个测试用的页面,每秒刷新N次。。。
之后再看。。。内存。。。
如果还长。。。那就是缓存的问题了。。。
如果不长。。。再看代码也来的急。。。。代码想要看一遍会死人的。
9 楼
tonyyl
2007-06-07
这样都不行的话,那就不知道了。。。
8 楼
tonyyl
2007-06-07
hibernate.connection.provider_class=C3p0ConnectionProvider,这样就该行了
7 楼
voff12
2007-06-06
按要在sessionFactory的hibernateProperties里配c3p0的属性,配置后,发现c3p0连接池后不起作用。tonyyl的4楼说法应该有误。
继续请。
继续请。
6 楼
voff12
2007-06-06
还是得看源代码,以求彻底解决此问题。
如果c3p0起作用的话:
tomcat起动后,打开浏览页后,可以看到设定的5个最小5个连接数(MySQL Adminstator观察)出现。
而且可以用Jprofire检测到c3p0包的使用情况:
。
当用户增加多时,数据库最大的连接数增到20后,连接数不再增加。
如果c3p0起作用的话:
tomcat起动后,打开浏览页后,可以看到设定的5个最小5个连接数(MySQL Adminstator观察)出现。
而且可以用Jprofire检测到c3p0包的使用情况:
。
当用户增加多时,数据库最大的连接数增到20后,连接数不再增加。
5 楼
lujh99
2007-06-06
我觉得有可能是使用上的问题吧,比如一次请求处理完了之后hibernate的session没有被关闭,数据库链接也被保持着,因为session中会缓存查询到的对象,倒是会出现内存不断增加的情况。
4 楼
voff12
2007-06-06
请问如何检测出可复用connection对象,如何知道连接池已经在起作用。
我以上的配置,我用JProfiler检测,找不到mchange(c3p0)的类包。
另外还有一个问题:就是内存在很多次查询blog,也就是显示blog时,内存一起往上涨,不知道是什么原因?(第二种配置)
我以上的配置,我用JProfiler检测,找不到mchange(c3p0)的类包。
另外还有一个问题:就是内存在很多次查询blog,也就是显示blog时,内存一起往上涨,不知道是什么原因?(第二种配置)
3 楼
tonyyl
2007-06-06
连接池不是说一下保持n个数据库连接,是可复用connection对象(创建此对象很耗资源),这似乎是基础吧。。。
发表评论
-
jsp参数过滤防注入的解决方法
2007-09-12 10:02 4276首先注入的类型分为参数数字型注入,参数字浮型注入,搜索框注入三 ... -
用hibernate竟然会把tomcat“干掉”,真是奇怪
2007-03-31 15:25 6123问题所在: 用struts1.0+hibernate3.1(m ... -
关于hibernate隔夜问题
2007-03-20 09:07 2085最近用hibernate作持久层(mysql),做了一个小网站 ... -
Struts在tomcat下的尝试
2007-01-20 20:53 1671struts是典型的MVC模式。不知这种模式的优势在那里? 今 ... -
hibernate在tomcat5.5下成功!
2007-01-19 23:23 1756<%@ page language="java ... -
hibernate在tomcat下的尝试2
2007-01-19 21:07 1955Cannot create JDBC driver of cl ...
相关推荐
数据库的链接包是MySQl数据库,链接使用的C3P0 SSH是 struts+spring+hibernate的一个集成框架,是目前比较流行的一种Web应用程序开源框架 现在的结构是,Struts负责显示层,Hibernate负责持久层,Spring负责中间的...
此项目sturts2+spring2.5+hibernate3.5+c3p0+log4j整合示例项目,数据库用的mysql5.0,代码注释详细,架构清晰,能帮助大家正确的理解如何快速整合ssh三个框架
spring +struts2+hibernate3整合的jar包集合,其中还包括了c3p0 和dpcp 数据库连接池所需要的jar,还有jdbc
里面包含JavaSE11与数据库MySQL8.0使用c3p0相连必须jar包,还有struts,spring,hibernate必须的jar包,也包含java9以上整合struts必须的三个jar包,还有struts与spring相连所需jar包,还包含ssh里需要用到的头标识
及c3p0-0.9.1.2.jar, mysql-connector-java-5.1.10-bin.jar 。 当时写的时候用的是JDK1.4,没有在JDK1.5下做测试,但在jdk1.5下应该没什么大问题,最多出现语法错误。 用的UTF-8编码。 有问题可在下载页面的评论...
这是一个Spring4.2.3+SpringMVC+Hibernate5.0.2整合后的Web Project,里面Jar包和配置文件齐全,下载下来即可投入开发(只需要配置Hibernate连接数据库的基本信息,项目下的readme.txt中提供了参考)。 整合详情请...
SSH整合学习笔记之spring与hibernate整合(二)之c3p0 spring与hibernate整合基于XML方式--c3p0数据库连接池的使用。
博文链接:https://wxinpeng.iteye.com/blog/203088
c3p0配置:mysql调试通过,oracle由于存在问题,未配置 spring配置式事务管理(jdk动态代理,每个service必须对应一个接口) BaseService里注入BaseDao 和transactionTemplate(用于编程式事务处理,只用于特殊...
由Struts2+spring4+hibernate4搭建而成的SSH框架,spring的配置采用了注解的方式。连接池用了c3p0,数据库是MySQL。
spring3+struts2+hibernate3的jar包,c3p0连接数据库,亲测可用
系统控制器、业务层、数据层采用spring注解方式,hibernate事务注入,c3p0数据库连接池等。又实现了权限拦截器、项目监听器、单元测试等功能。 页面简洁大气美观,系统耦合度小,可配置度高,几乎包含了全部常用...
内容概要:c3p0连接池需要jar包.rar以及相关配置文件 C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。目前使用它的开源项目有Hibernate、Spring等。 适合人群:正在学习...
C3P0是一个随Hibernate一同分发的开源的JDBC连接池, 它位于lib目录下。 包括了实现jdbc3和jdbc2扩展规范说明的Connection 和Statement 池的DataSources 对象.
通过c3p0连接池jar包可以连接到数据库, C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。目前使用它的开源项目有Hibernate,Spring等。
最新SSH(springmvc4.0+spring4.0+hibernate4.3.4)全注解...C3PO数据库连接池,代理事务 初来乍到,不到位的地方还请大家多给给宝贵的意见,不明白的地方随时Q我 21990226,错误的地方狠狠指出 供稿---坐看云起的从容
C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。目前使用它的开源项目有Hibernate,Spring等。C3P0数据源在项目开发中使用得比较多。导入相关jar包c3p0-0.9.2-pre1.jar、...
ehcache二级缓存,c3p0连接池,文件上传,dom4j,mysql数据库驱动,jscharts图表统计图走势,JSTL,struts日历控件包,base64加密,Excel文件生成,邮件发送,log4j以及log4j配置文件,mysql数据库连接Properties...
C3P0 JUnit Log4j Jackson FastJson 系统特点 用户、角色和权限管理 设备和文件管理 使用 POI 将设备列表导出到 Excel 文件 基于Spring AOP的用户访问日志 使用 JFreeChart 的用户统计图表显示 前端和后端通过 JSON ...
本系统使用Struts2+Spring+Hibernate架构,数据库使用MySQL,连接池使用c3p0。 模仿花礼网进行前端设计与开发,实现网站导航、商品分类展示,商品详情、商品检索、购物车等功能。 使用EasyUI实现后台对商品分类、商品...