SSH整合过程中无法连接数据库的问题

原创 2015年11月19日 17:07:03

终于学完了SSH三大框架,开始整合来开发一些网页,没想到在整合的过程中遇到了问题,卡了很久,用了一下午终于解决,于是分享出来希望能帮到其他朋友。
场景描述:导入了spring和hibernate的jar包,并且配置好了相关配置文件,利用spring来实现声明式事务管理,实现了service层和dao层,然后进行测试,通过service来保存一个对象,结果报错,错误信息如下:

org.springframework.transaction.CannotCreateTransactionException: Could not open Hibernate Session for transaction; nested exception is org.hibernate.exception.JDBCConnectionException: Cannot open connection
    at org.springframework.orm.hibernate3.HibernateTransactionManager.doBegin(HibernateTransactionManager.java:599)
    at org.springframework.transaction.support.AbstractPlatformTransactionManager.getTransaction(AbstractPlatformTransactionManager.java:377)
    at org.springframework.transaction.interceptor.TransactionAspectSupport.createTransactionIfNecessary(TransactionAspectSupport.java:263)
    at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:101)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:171)
    at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:89)
    at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:171)
    at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:204)
    at $Proxy4.savePage(Unknown Source)
    at com.tt.test.TestSpring.TestService(TestSpring.java:23)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.junit.internal.runners.TestMethodRunner.executeMethodBody(TestMethodRunner.java:99)
    at org.junit.internal.runners.TestMethodRunner.runUnprotected(TestMethodRunner.java:81)
    at org.junit.internal.runners.BeforeAndAfterRunner.runProtected(BeforeAndAfterRunner.java:34)
    at org.junit.internal.runners.TestMethodRunner.runMethod(TestMethodRunner.java:75)
    at org.junit.internal.runners.TestMethodRunner.run(TestMethodRunner.java:45)
    at org.junit.internal.runners.TestClassMethodsRunner.invokeTestMethod(TestClassMethodsRunner.java:66)
    at org.junit.internal.runners.TestClassMethodsRunner.run(TestClassMethodsRunner.java:35)
    at org.junit.internal.runners.TestClassRunner$1.runUnprotected(TestClassRunner.java:42)
    at org.junit.internal.runners.BeforeAndAfterRunner.runProtected(BeforeAndAfterRunner.java:34)
    at org.junit.internal.runners.TestClassRunner.run(TestClassRunner.java:52)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:38)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:460)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:673)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:386)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:196)
Caused by: org.hibernate.exception.JDBCConnectionException: Cannot open connection
    at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:99)
    at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:66)
    at org.hibernate.exception.JDBCExceptionHelper.convert(JDBCExceptionHelper.java:52)
    at org.hibernate.jdbc.ConnectionManager.openConnection(ConnectionManager.java:449)
    at org.hibernate.jdbc.ConnectionManager.getConnection(ConnectionManager.java:167)
    at org.hibernate.jdbc.JDBCContext.connection(JDBCContext.java:142)
    at org.hibernate.transaction.JDBCTransaction.begin(JDBCTransaction.java:85)
    at org.hibernate.impl.SessionImpl.beginTransaction(SessionImpl.java:1463)
    at org.springframework.orm.hibernate3.HibernateTransactionManager.doBegin(HibernateTransactionManager.java:558)
    ... 29 more
Caused by: java.sql.SQLException: No suitable driver
    at java.sql.DriverManager.getConnection(Unknown Source)
    at java.sql.DriverManager.getConnection(Unknown Source)
    at org.hibernate.connection.DriverManagerConnectionProvider.getConnection(DriverManagerConnectionProvider.java:133)
    at org.hibernate.jdbc.ConnectionManager.openConnection(ConnectionManager.java:446)
    ... 34 more

于是百度错误原因,看了很多解决方案,都没办法解决,都是泪………………结果整了一下午都没解决,后来想到是不是因为没有在spring配置文件中显式地配置数据库,于是在spring配置文件中加入如下配置:

<bean
        class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="locations">
            <value>classpath:jdbc.properties</value>
        </property>
    </bean>

    <bean id="dataSource" destroy-method="close"
        class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="${jdbc.driverClassName}" />
        <property name="url" value="${jdbc.url}" />
        <property name="username" value="${jdbc.username}" />
        <property name="password" value="${jdbc.password}" />
    </bean>

同时修改sessionfactory,代码如下:

<bean id="sessionFactory"
        class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource"></property>
        <property name="mappingResources">
            <list>
                <value>com/tt/domain/Page.hbm.xml</value>
            </list>
        </property>
        <property name="hibernateProperties">
            <value>
                hibernate.dialect=org.hibernate.dialect.MySQLDialect
            </value>
        </property>
    </bean>

jdbc.properties内容如下:

jdbc.driverClassName=com.mysql.jdbc.Driver
jdbc.url=jdbc\:mysql\://localhost\:3306/itcast_sh_hibernate
jdbc.username=root
jdbc.password=root

但是配置好后测试又报错,原因是少了两个包,导入这两个包:commons-dbcp.jar和commons-pool.jar,于是问题解决。

PS:这部分配置是看着教学视频和老师同步做的,可是视频里老师测试就完全没问题,我一测就崩了,泪奔…………不过不管怎么样错误还是解决了,继续整合SSH。

版权声明:本文为博主原创文章,未经博主允许不得转载。

java中,如何处理点击关闭按钮 只是关闭当前的界面

java中,点击关闭按钮 只是关闭当前的界面??   2007-12-20 11:38 提问者: younuobenben|浏览次数:2927次 只是让它关闭当前的界面,不是全部关闭?大家指...

U盘引导安装CentOS,拔掉U盘后无法启动的问题

现象描述: 用U盘启动盘单独安装CentOS到一块硬盘上,然后拔掉U盘后就无法启动硬盘中的操作系统了。 原因: 使用U盘引导安装默认会把grub引导程序写入U盘的mbr扇区。 解决: 第一种...

SSH整合过程中中文乱码问题的解决方案(以mysql数据库为简单案例)

欢迎使用Markdown编辑器写博客本Markdown编辑器使用StackEdit修改而来,用它写博客,将会带来全新的体验哦: Markdown和扩展Markdown简洁的语法 代码块高亮 图片链接和...

一个基于SSH的实践项目在开发过程中遇到的问题汇总

项目名称:东方物流系统

关于SSH2框架搭建过程中出现的问题的总结

以前接触过SSH框架,但是一直都没有用过,然后这段时间又重新回顾了一下,当然,期间也碰到了不少问题,然后就在网上查相关资料,折腾了一番,也学到了不少东西,所以决定整理下来。使用的IDE工具是Myecl...

SSH+ORACLE案例过程中出现的额一系列问题的可用解决方案(一)

1.         在添加数据的过程中可能出现序列号找不到的情况,首先在数据库中建立一个序列SEQUENCE,然后在hbm.xml配置文件中将含有sequence声明的语句中加入以下语句SEQUEN...
  • iti168
  • iti168
  • 2011年07月17日 12:00
  • 318

SSH AOP 学习过程中遇到的问题...

首先我保证了在没加AOP实现之前,代码是能正常运行的. 然后学习SSH使用AOP在action的方法前添加权限控制,该文就是记录出现的错误信息.. 先说明用xml注解AOP起先是使用的anno...
  • kvgnt
  • kvgnt
  • 2011年02月20日 22:05
  • 2884

java SSH + extj 项目过程中遇到的问题及注意点(二)

1.SVN版本控制问题。svn是个版本控制工具,适合于团队多人共同开发一个项目,挺有用的,但是总会出现各种问题,不得不一遍遍的重新上传删除等,恼人的很,即使本着说烂了的”先更新再提交“原则,依旧还是各...
  • lesaqiu
  • lesaqiu
  • 2015年10月21日 15:47
  • 440

项目____SSH框架下Ajax数据通信过程中数据读取不到的问题

action代码: public String getOgcConfigById(){ CData ogc = this.ddsManage.getOgcConfigById(data); t...

SSH技术分析,整合过程中错误,应用前景--浅谈

ssh框架的技术分析:     摘 要:针对当前Web应用程序开发面临的问题,结合目前比较流行的开源框架Spring、Struts和Hibernate,提出了一种开发J2EE Web应用的轻量级解决...
  • numbibi
  • numbibi
  • 2012年04月25日 11:36
  • 1671
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SSH整合过程中无法连接数据库的问题
举报原因:
原因补充:

(最多只允许输入30个字)