异常处理:ExceptionInInitializerError

Exception in thread “main” java.lang.ExceptionInInitializerError
如何处理这个异常,用idea写的代码
***居中并且带尺寸的图片: ***在这里插入图片描述

代码如下:

public class Book {
    public static void main(String[] args) throws Exception {
        //1.注册驱动
        Class.forName("com.mysql.jdbc.Driver");
        //2.获取连接对象
        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/book","root","root");
        //3.创建SQL执行语句
        Statement s = conn.createStatement();
        //4.执行SQL语句
        String sql = "SELECT * FROM emp";
        s.execute(sql);
        System.out.println("执行完毕!");
        //5.关闭资源
        conn.close();
    }
}

public class DBUtils {
    private static BasicDataSource ds;
    static {
        //创建属性对象
        Properties p = new Properties();
        //获取文件输入流  利用类加载器
        InputStream ips = DBUtils.class.getClassLoader()
                .getResourceAsStream("jdbc.properties");
        //让文件和配置对象建立关系
        try {
            p.load(ips);
        } catch (IOException e) {
            e.printStackTrace();
        }
        String driver = p.getProperty("driver");
        String url = p.getProperty("url");
        String username = p.getProperty("username");
        String password = p.getProperty("password");
        System.out.println(driver+","+url+","+username+","+password);

//				//注册驱动
//				Class.forName(driver);
//				//创建连接对象
//				Connection conn = DriverManager.getConnection(url,username,password);

        //创建连接池对象
        ds = new BasicDataSource();
        //设置连接信息
        ds.setDriverClassName(driver);
        ds.setUrl(url);
        ds.setUsername(username);
        ds.setPassword(password);
        //设置初始连接数量
        ds.setInitialSize(3);
        ds.setMaxActive(5);//最大连接数量
    }
    public static Connection getConn() throws Exception{

        //从连接池中获取连接并返回
        return ds.getConnection();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值