连接池

一:使用数据库连接池可以较好的优化数据库的性能

二:编写连接池需实现java.sql.DataSource接口。DataSource接口中定义了两个重载的getConnection方法:

•Connection getConnection()

•Connection getConnection(String username, String password)

实现DataSource接口,并实现连接池功能的步骤:

•在DataSource构造函数中批量创建与数据库的连接,并把创建的连接加入LinkedList对象中。

•实现getConnection方法,让getConnection方法每次调用时,从LinkedList中取一个Connection返回给用户。

•当用户使用完Connection,调用Connection.close()方法时,Collection对象应保证将自己返回到LinkedList中,而不要把conn还给数据库。

•Collection保证将自己返回到LinkedList中是此处编程的难点。

三:在java中,要对某一方法进行增强的三种方式1,写一个子类,2写一个包装类(包装设计模式),3用动态代理

四:包装设计模式步骤

1写一个类实现与被增强的类相同的接口或父类

2在类中定义一个变量记住需要增强的对象

3定义构造方法,接受被增强对象

4覆盖想增强的方法

5对不想增强的方法直接调用被增强对象的方法

五:DBCP是Apache组织下的开源连接池实现,使用这个数据源,需要Commons-dbcp.jar(连接池的实现) ,Commons-pool.jar(连接池实现的依赖库)

六:c3p0数据源。image

七:tomcat自带连接池,对tomcat进行配置,可以在config的server.xml中配置,或者在contilina下新建content.xml,或者,在当前工程中的META-INF下新建context.xml来配置连接池

八:JNDI---JAVA命名和目录接口,对应于javax.naming包,这种技术主要用于把一个java对象放在一个容器中,并为容器中的java对象取一个名称,如果想获取这个java对象,只需通过名称检索就行,代码如下:

Context initCtx = new InitialContext();

Context envCtx = (Context) initCtx.lookup("java:comp/env");

DataSource ds = (DataSource)envCtx.lookup("jabc/xxx");

九:如何在自己的方法中调用其他方法,可以通过定义一个接口,接受这个接口的参数,让用户实现这个接口传递进来。也就是策略模式

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值