普通网友 2018-12-11 08:09 采纳率: 53.3%
浏览 3065
已采纳

使用dbcp连接数据库报错java.lang.NumberFormatException: For input string: "20 "?

内容:
换了一个工程就可以跑得动
报错:

java.lang.NumberFormatException: For input string: "20 "
 at java.base/java.lang.NumberFormatException.forInputString(Unknown Source)
 at java.base/java.lang.Integer.parseInt(Unknown Source)
 at java.base/java.lang.Integer.parseInt(Unknown Source)
 at org.apache.commons.dbcp.BasicDataSourceFactory.createDataSource(BasicDataSourceFactory.java:228)
 at com.ekihin.part01.day20.DBCPDemo.<clinit>(DBCPDemo.java:21)
 at com.ekihin.part01.day20.DBCPDemoTest.main(DBCPDemoTest.java:15)
Exception in thread "main" java.lang.NullPointerException
 at com.ekihin.part01.day20.DBCPDemo.getConnection(DBCPDemo.java:29)
 at com.ekihin.part01.day20.DBCPDemoTest.main(DBCPDemoTest.java:15)

类:

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

public class DBCPDemoTest {
 public static void main(String[] args) throws Exception {
  Connection conn = null;
  PreparedStatement ps = null;
  ResultSet rs = null;
  String sql = "Update emp set ename = ? where ename = ? ";

  conn = DBCPDemo.getConnection();
  ps = conn.prepareStatement(sql);
  ps.setObject(1, "彭奕滨");
  ps.setObject(2, "ekihin");
  int rows = 0;
  rows = ps.executeUpdate();
  System.out.println(rows);

  DBCPDemo.closeAll(conn, ps, rs);

 }
}

import java.io.IOException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;

import javax.sql.DataSource;

import org.apache.commons.dbcp.BasicDataSourceFactory;

public class DBCPDemo {
 private static DataSource ds = null;

 static {
  Properties pt = new Properties();
  try {
   pt.load(DBCPDemo.class.getClassLoader().getResourceAsStream("dbcpconfig.properties"));
   ds = BasicDataSourceFactory.createDataSource(pt);
  } catch (Exception e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
 }
  public static Connection getConnection() throws SQLException{
   //返回一个连接对象,不要用DriverManager获取,而是连接池中获取
   return ds.getConnection();
  }

  //关闭所有资源的统一代码
  public static void closeAll(Connection conn,Statement st,ResultSet rs){
   //负责关闭
   if(conn != null){
    try {
     conn.close();
    } catch (SQLException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }
   }
   if(st != null){
    try {
     st.close();
    } catch (SQLException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }
   }
   if(rs != null){
    try {
     rs.close();
    } catch (SQLException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }
   }
  }
}
  • 写回答

4条回答 默认 最新

  • 哈喽大海豚 2018-12-11 08:29
    关注

    你的配置文件里面20后面多了一个空格。。。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 如何在3D高斯飞溅的渲染的场景中获得一个可控的旋转物体
  • ¥88 实在没有想法,需要个思路
  • ¥15 MATLAB报错输入参数太多
  • ¥15 python中合并修改日期相同的CSV文件并按照修改日期的名字命名文件
  • ¥15 有赏,i卡绘世画不出
  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败