弄了一个spring+ibatis的例子,在测试的时候报了下面的错误:

Exception in thread "main" org.springframework.jdbc.UncategorizedSQLException: SqlMapClient operation; uncategorized SQLException for SQL []; SQL state [null]; error code [0];   
--- The error occurred in config/sqlmap/user.xml.  
--- The error occurred while executing update.  
--- Check the          INSERT INTO User(UserName,PassWord,Age) VALUES (?, ?, ?);     .  
--- Check the SQL Statement (preparation failed).  
--- Cause: org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (validationQuery didn't return a row); nested exception is com.ibatis.common.jdbc.exception.NestedSQLException:   
--- The error occurred in config/sqlmap/user.xml.  
--- The error occurred while executing update.  
--- Check the          INSERT INTO User(UserName,PassWord,Age) VALUES (?, ?, ?);     .  
--- Check the SQL Statement (preparation failed).  
--- Cause: org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (validationQuery didn't return a row)
at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:83)
at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80)
at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:80)
at org.springframework.orm.ibatis.SqlMapClientTemplate.execute(SqlMapClientTemplate.java:203)
at org.springframework.orm.ibatis.SqlMapClientTemplate.insert(SqlMapClientTemplate.java:364)
at com.mynote.web.dao.impl.UserDaoImpl.registerUser(UserDaoImpl.java:11)
at com.mynote.web.service.impl.UserServiceImpl.registerUser(UserServiceImpl.java:13)
at com.mynote.web.junit.IbatisDemo.main(IbatisDemo.java:21)
Caused by: com.ibatis.common.jdbc.exception.NestedSQLException:   
--- The error occurred in config/sqlmap/user.xml.  
--- The error occurred while executing update.  
--- Check the          INSERT INTO User(UserName,PassWord,Age) VALUES (?, ?, ?);     .  
--- Check the SQL Statement (preparation failed).  
--- Cause: org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (validationQuery didn't return a row)
at com.ibatis.sqlmap.engine.mapping.statement.MappedStatement.executeUpdate(MappedStatement.java:107)
at com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate.insert(SqlMapExecutorDelegate.java:393)
at com.ibatis.sqlmap.engine.impl.SqlMapSessionImpl.insert(SqlMapSessionImpl.java:82)
at org.springframework.orm.ibatis.SqlMapClientTemplate$8.doInSqlMapClient(SqlMapClientTemplate.java:366)
at org.springframework.orm.ibatis.SqlMapClientTemplate.execute(SqlMapClientTemplate.java:200)
... 4 more
Caused by: org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (validationQuery didn't return a row)
at org.apache.commons.dbcp.BasicDataSource.createPoolableConnectionFactory(BasicDataSource.java:1549)
at org.apache.commons.dbcp.BasicDataSource.createDataSource(BasicDataSource.java:1388)
at org.apache.commons.dbcp.BasicDataSource.getConnection(BasicDataSource.java:1044)
at org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.java:111)
at org.springframework.jdbc.datasource.TransactionAwareDataSourceProxy$TransactionAwareInvocationHandler.invoke(TransactionAwareDataSourceProxy.java:224)
at com.sun.proxy.$Proxy4.prepareStatement(Unknown Source)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at com.ibatis.common.jdbc.logging.ConnectionLogProxy.invoke(ConnectionLogProxy.java:53)
at com.sun.proxy.$Proxy5.prepareStatement(Unknown Source)
at com.ibatis.sqlmap.engine.execution.SqlExecutor.prepareStatement(SqlExecutor.java:497)
at com.ibatis.sqlmap.engine.execution.SqlExecutor.executeUpdate(SqlExecutor.java:75)
at com.ibatis.sqlmap.engine.mapping.statement.MappedStatement.sqlExecuteUpdate(MappedStatement.java:216)
at com.ibatis.sqlmap.engine.mapping.statement.MappedStatement.executeUpdate(MappedStatement.java:94)
... 8 more
Caused by: java.sql.SQLException: validationQuery didn't return a row
at org.apache.commons.dbcp.PoolableConnectionFactory.validateConnection(PoolableConnectionFactory.java:660)
at org.apache.commons.dbcp.BasicDataSource.validateConnectionFactory(BasicDataSource.java:1558)
at org.apache.commons.dbcp.BasicDataSource.createPoolableConnectionFactory(BasicDataSource.java:1545)
... 23 more

折腾了很久,才发现,问题在于我的spring配置里面有下面一条:

<property name="validationQuery" value="select User.ID from User"></property>

validationQuery是用于验证连接是否成功的查询SQL语句,但是当数据库表中没有数据时,就会出现异常。

我的User表是空的,没有默认数据,所以运行时就出错了。如果在表中插入一条记录,就不会出现上述问题了。

validationQuery didn't return a row相关推荐

  1. spring+dbcp连接池源码分析

    Spring对数据库连接池的支持 常见的数据库连接池有c3p0,dbcp以及druid,这里使用的是dbcp. 前文中使用DataSourceUtils获取和释放connection,代码如下: // ...

  2. 利用二维数组(double[])实现一个矩阵类:Matrix。要求提供以下方法:(1)set(int row, int col, double value):将第row行第col列的元素赋值为valu

    利用二维数组(double[])实现一个矩阵类:Matrix.要求提供以下方法:(1)set(int row, int col, double value):将第row行第col列的元素赋值为valu ...

  3. 金仓数据库KingbaseES之存储过程的RETURN语句

    概述 RETURN语句一共有三个命令可以用来从函数中返回数据: RETURN RETURN NEXT RETURN QUERY RETURN命令 语法: RETURN RETURN expressio ...

  4. C语言三字棋优化,实现ROW*COL个格子,ZI字棋

    三字棋优化 ,主要是针对棋局大小及方式的优化,可实现ROW*COL个格子,ZI字棋.也即棋盘方式,与下法都可以变化. 其中game.c中分别写了纯三字棋>优化>ROW*COL三字棋> ...

  5. 经常用得到的安卓数据库基类

    //创建数据库 public class DBCreate { public static void CreateDatabase(SQLiteDatabase db) { db.beginTrans ...

  6. java解数独_java解数独

    先输入要解的数独,采用多维数组来保存其中的值,未填数字的地方,初始化为0,然后采用递归的方法来解数独. 直接上代码: /*** *@authorwalker **/ public classSudok ...

  7. 力扣(LeetCode)刷题,简单+中等题(第32期)

    目录 第1题:数组的度 第2题:托普利茨矩阵 第3题:爱生气的书店老板 第4题:翻转图像 第5题:有效的数独 第6题:无重复字符的最长子串 第7题:区域和检索 - 数组不可变 第8题:二维区域和检索 ...

  8. ADPRL - 近似动态规划和强化学习 - Note 10 - 蒙特卡洛法和时序差分学习及其实例 (Monte Carlo and Temporal Difference)

    Note 10 蒙特卡洛法和时序差分学习 Monte Carlo and Temporal Difference 蒙特卡洛法和时序差分学习 Note 10 蒙特卡洛法和时序差分学习 Monte Car ...

  9. 帕斯卡三角形(Pascal's triangle)

    // The following code is compiled on VC2005 // #include "stdafx.h" /*--------------------- ...

最新文章

  1. 2018-2019-1 20165214 《信息安全系统设计基础》第六周学习总结
  2. 软件配置文件如何读写
  3. filter函数的用法_函数周期表丨筛选丨表丨CALCULATETABLE
  4. 为新研究准备好一块用武之地:最全任务型对话数据调研
  5. 关于jquery的ajax编码的另类解决方案,巨简便
  6. word List 50
  7. 01-基本配置与测试
  8. 计算机系统结构开设学校,计算机系统结构专业介绍及考研院校排名
  9. java 方法详解_Java方法详解
  10. 信息内容安全-基于微博热搜的yuqing监测系统
  11. 5G聚合路由器有哪些优势?能应用在哪些场景?
  12. CSS深入理解之absolute
  13. 主数据管理系统(MDM)的四种实现风格
  14. 坐标转换系列三 基于开源的proj4,封装成工具
  15. java中关键字缺省(default)
  16. 论文的可复现性,能否量化分析?
  17. Matlab自学笔记四:调用函数基本方法、传递参数、函数工作区、命令语法、调用匿名函数
  18. 佳能eosr控制环能否计算机控制,镜头不够EF口来凑 佳能EOS R转接性能测试
  19. 教育培训机构的信息化管理,要先从这四大业务场景做起
  20. 想成为六西格玛黑带大师?这些你了解吗

热门文章

  1. 城市轨道交通计算机联锁的特殊要求,城市轨道交通联锁功能实现论文
  2. 苹果手机解压缩软件_macOS免费解压缩软件,要不要试一下360压缩?
  3. 天秤座的骑友,量身定制的骑游运动,爱上骑行的好处和特点
  4. modernizr_Modernizr入门
  5. 在VS中实现QT的多国语言翻译
  6. MySql 查询有课教师的姓名、职称及其所授的课程名
  7. progressbar
  8. 【luogu CF1569D】Inconvenient Pairs(思维)
  9. iphone主板序列号_苹果承认硬件缺陷,iPhone 8 主板更换计划序列号查询地址
  10. 【HTML——酷炫烟花】(效果+代码)