jdbc连接问题——com.alibaba.druid.pool.DruidDataSource error

在idea使用数据库连接池druid连接报错为com.alibaba.druid.pool.DruidDataSource error时候可能是mysql的jdbc jar包版本或者druid jar包版本问题造成

druid下载地址:https://repo1.maven.org/maven2/com/alibaba/druid/

mysql官网地址:MySQL :: Download Connector/J

下载最新版本导入lib中即可

druid jar下载及导入:

下载:如图

 

 导入:

复制到lib下

 加入到模块中:选中右键选中add....

 选中Model Library点击ok

 

附上druid相关内容:

druid

(数据库连接池实现技术,由阿里巴巴提供的)
    1. 使用步骤:
        (1).导入jar包 
        (2). 定义配置文件:是properties形式,可以叫任意名称,可以放在任意目录下
        (3). 加载配置文件。Properties
        (4). 获取数据库连接池对象:通过工厂来来获取  DruidDataSourceFactory
        (5). 获取连接:getConnection
          


             //加载配置文件
            Properties pro = new Properties();
            InputStream is = DruidDemo.class.getClassLoader().getResourceAsStream("druid.properties");
            pro.load(is);
            //获取连接池对象
            DataSource ds = DruidDataSourceFactory.createDataSource(pro);
            //获取连接
            Connection conn = ds.getConnection();


    2. 定义工具类
        (1). 定义一个类 JDBCUtils
        (2). 提供静态代码块加载配置文件,初始化连接池对象
        (3). 提供方法
             获取连接方法:通过数据库连接池获取连接
             释放资源
             获取连接池的方法

  
           public class JDBCUtils {

                //1.定义成员变量 DataSource
                private static DataSource ds ;
            
                static{
                    try {
                        //1.加载配置文件
                        Properties pro = new Properties();
                        pro.load(JDBCUtils.class.getClassLoader().getResourceAsStream("druid.properties"));
                        //2.获取DataSource
                        ds = DruidDataSourceFactory.createDataSource(pro);
                    } catch (IOException e) {
                        e.printStackTrace();
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            
                /**
                 * 获取连接
                 */
                public static Connection getConnection() throws SQLException {
                    return ds.getConnection();
                }
            
                /**
                 * 释放资源
                 */
                public static void close(Statement stmt,Connection conn){
                   /* if(stmt != null){
                        try {
                            stmt.close();
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }
                    }
            
                    if(conn != null){
                        try {
                            conn.close();//归还连接
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }
                    }*/
            
                   close(null,stmt,conn);
                }
            
            
                public static void close(ResultSet rs , Statement stmt, Connection conn){
            
            
                    if(rs != null){
                        try {
                            rs.close();
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }
                    }
            
            
                    if(stmt != null){
                        try {
                            stmt.close();
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }
                    }
            
                    if(conn != null){
                        try {
                            conn.close();//归还连接
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }
                    }
                }
            
                /**
                 * 获取连接池方法
                 */
            
                public static DataSource getDataSource(){
                    return  ds;
                }
            
            }


     

  • 12
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
`com.alibaba.druid.pool.DruidDataSource` 报错一般是因为数据库连接出现了问题,错误信息通常会提供一些有用的提示,可以根据错误信息进行排查和解决。 通常出现 `com.alibaba.druid.pool.DruidDataSource` 报错的原因有以下几种: 1. 数据库连接配置错误:检查数据库连接的配置信息是否正确,例如数据库地址、用户名、密码等。 2. 数据库连接池已满:如果连接池已经达到最大连接数,那么新的连接请求将会被拒绝,此时可以尝试增加连接池大小或者优化数据库操作,减少连接数的消耗。 3. 数据库连接超时:如果连接在一段时间内没有被使用,那么数据库会自动关闭连接,此时再次使用该连接时就会出现连接超时的错误。 4. 数据库连接中断:如果数据库连接在使用过程中突然中断,那么就会出现连接中断的错误,此时可以尝试重新连接数据库或者检查网络连接是否正常。 5. 数据库访问权限不足:如果数据库连接的用户没有足够的权限访问数据库,那么就会出现访问权限不足的错误,此时可以尝试修改数据库用户的权限。 针对不同的错误原因,可以采取不同的解决方法,例如重新配置数据库连接、增加连接池大小、优化数据库操作等等。同时,在使用 `com.alibaba.druid.pool.DruidDataSource` 连接数据库时,也需要注意一些常见问题,例如线程安全、连接泄露等等,避免出现错误和性能问题

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值