2 u010294107 u010294107 于 2014.11.26 10:52 提问

数据库连接单例和连接池效率区别在哪?

数据库连接问题。new一个数据库的连接对象是耗时耗资源的,因此不可能对每个请求都做一遍连接创建和关闭的操作,网上给的方法一般采用连接池。我的疑问就是,我如果采用单例模式,
这样的话,如果是多个线程请求数据库操作,那么直接调用静态getInstance方法(对此方法加锁),取得同一个数据库连接对象进行数据库操作,是不是可行的。我的理解是Connection在第一次实例化时,已经确定了它要连接时那个数据库,以后的操作也不会改变这些属性,因此不存在线程安全问题,而针对数据库本身的操作,数据应该也会提供一套同步机制,避免“脏数据”。这样的话,单例模式和池化相比,采用哪种方式更好?

6个回答

dollyn
dollyn   Rxr 2014.11.26 13:47

如果你是小型应用,保证不会有多线程同时使用这一条连接,那没问题;
多线程用同一条链接肯定是会出问题的,这个你可以自己写代码测试。

连接池的目的是为了减少反复的创建和关闭连接,同时又在一定程度上满足多线程可以分别用多条连接。

csdn1457570681
csdn1457570681   2014.11.26 11:06

建议思考一下servlet采用的单实例多线程机制,单例模式与连接池似乎并不矛盾

ys8616270
ys8616270   2014.11.26 11:06

数据库应该也会提供一套同步机智(why ? ) 。。事务如何保证?????????? ?

xuzuning
xuzuning   Ds   Rxr 2014.11.26 11:13

这是两个不同的概念
数据库连接单例是指在你项目运行期间,始终只有一个数据库连接。即这个链接在程序中是复用的
而连接池维持了到数据库服务器的多个物理连接,每当有新的数据库连接请求时,优先使用已存在的空闲的物理连接

显然前者是针对一个项目内部的
而后者是针对多个项目的(当然也适用项目内的多个独立连接)

zhoumeng1107
zhoumeng1107   2014.11.26 12:51

其实在你频繁使用连接单例时,程序会自动为你建立连接痴,效率的区别在于你对sql的操作频率!

arjick
arjick   2014.12.03 13:29

减少连接和销毁时间的消耗

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!