Druid

Druid

1.什么是数据库连接池,数据库连接池的好处是什么

数据库连接池:
   可以分配,释放,管理数据库连接对象,当前某个连接对象释放之后,会归还到连接池中,大大提高了JDBC操作数据库性能!
   弊端:维护成本高; (维护它druid的版本以及监控它的连接数量)
    好处:可以设置参数,将数据库连接池进行调优;
    每一个线程都会使用自己的连接对象!
    前某个连接对象释放之后,会归还到连接池中,等待下一次利用(大大提高了连接对象的使用率)
  
   	在连接池中:会初始化一些连接数量(提供了很多参数)
   	initialSize:初始化数量
   	maxActive:最大激活数量
   	maxWait:最大等多等待时间(毫秒值)
   	maxidle:最大空闲数量
   	minidel:最小空闲数量
   	...
   	...

2.通过Druid获取数据源的操作步骤

//1)导包
druid-1.1.10.jar
//2)加入连接池的配置文件
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/day13
username=root
password=123456
initialSize=5
maxActive=10
maxWait=3000
//3)读取配置文件 
   InputStream inputStream =  当前类.class.getClassLoader().getResourceAsStream("xxx.properties") ;
//4)创建属性集合列表
Properties prop = new Properties() ;
prop.load(inputStream) ;
//5)获取数据源----DruidDataSourceFactory
//public static DataSource createDataSource(Properties prop)
DataSource ds = DruidDataSourceFactory.createDataSource( prop) ;
//DataSource替代了DriverManager: Connection getConnection() ;
//6)获取连接对象
Connection conn = ds.getConnection() ;
//使用连接对象

3.封装jdbc工具类,加入数据库连接池以及ThreadLocal的步骤

//为了模拟真实场景:一个线程使用自己的连接对象---操作数据库
class DruidJdbcUtils{
    //成员变量
    private static DataSource ds ;  //数据源
    private staitc ThreadLocal<Connection> t1 = new ThreadLocal<>() ;//当前线程对象
    
    private DruidJdbcUtils(){}
    
    //静态代码块
    static{
         //1)需要读取连接池的配置文件
         //创建属性集合列表
        Propereties prop = new Properties() ;
         //获取连接池配置文件的所在的输入流对象
         InputStream inputStream  =   DruidJdbcUtils.class.getClassLoader().getRresourceAsStream("druid.properties") ;
        //将资源输入流加载到属性列表中
        prop.load(inputStream) ;
        
   		 //2)获取数据源---给成员变量ds赋值
        //使用德鲁伊的工厂
        ds = DruidDataSourceFactory.createDataSource(prop) ;
    }
    
    //封装:获取连接对象的功能
    public static Connection getConnection(){
        //首先:从当前线程中获取连接对象
        Connection conn = t1.get() ;
        if(conn ==null){
            //当前线程持有连接对象
            //从数据源:连接池中获取
            conn =  ds.getConnection() ;
            //将连接对象绑定到当前线程中
            t1.set(conn) ;
        }
        return conn ;
    }
    //关闭资源---是否conn对象---close()---->t1.remove()解绑; 从当前线程中解绑
   
};

4.Common-dbutils的使用

//Apache提供开源的工具类库:针对JDBC简易封装,简化原生jdbc的书写格式;

//1)导入mysql驱动包,还需要到druid包,dbutils的核心jar包,还需要使用单元测试junit以及junit的依赖包
//2)创建执行对象
//public QueryRunner(DataSource ds)  : 自动提交模式
//public QueryRunner() :手动提交模式
QueryRunner qr = new QueryRunner(DruidJdbcUtils.getDataSource()) ;
//3)准备sql----参数化的sql语句
//DML语句  
String sql = "insert into 表名 values(?,?,?,?.....)" ;
String sql2 = "delete from 表名 where 字段名称 = ?" ;
String sql3 = "update 表名 set 字段名称 = ?,字段名称2 = ? where 字段名称 = ?" ;
//QueryRunner 通用方法 update(String sql,Object...params)  
               //update(Connection conn,String sql,Object...params):手动提交,通用更新操作

//DQL语句
String sql4 = "select 字段列表 from 表名 limit ?,?" ;
//QueryRunner 通用方法 query(String sql,ResultSetHandler<T> rsh,Object...params)

//ResultSetHandler接口:针对查询的结果集数据表的一种处理

//实现类
//BeanListHandler<T>:将查询的多条记录封装到List集合中  List<T>
//BeanHandler<T>:将查询的某条记录封装到Java实体中
//ScalarHandler<>() :一般通过聚合函数查询的单行单例的数据----->Object---->转换成我们需要的类型
   //举例:查询 总记录数  -----返回值int
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值