C站训练营学员-20200119
2018-12-11 08:09
采纳率: 50%
浏览 2.9k
已采纳

使用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后面多了一个空格。。。

    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • yikeshuo 2018-12-11 08:14

    https://www.cnblogs.com/dedebug/p/5825842.html 可能是有些类型 在不同的机器上 意义不一样

    评论
    解决 无用
    打赏 举报
  • 木瞳 2018-12-11 08:27

    意思是类型转换异常,字符串"20"不能转换为数字类型,

    评论
    解决 无用
    打赏 举报
  • DreamTHT 2018-12-11 10:00

    类型转换报错,字符串20转换数字类型报错,应该是20后面带上了空格。

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题