描述ADO.net属性进行仔细研究

进行程序执行的时候。如果是Pooling 为True,ADO.net属性就把当前地Connection放到Connection Pool并且维护与数据库之间地连接。相应情况下还会判断Connection Lifetime(默认为0)属性,0代表无限大。

10多年的红桥网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。网络营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整红桥建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联公司从事“红桥网站设计”,“红桥网站推广”以来,每个客户项目都认真落实执行。

如果Connection存在地时间超过了Connection LifeTime,ADO.net属性就会关闭地Connection相应情况下断开与数据库地连接,而不是重新保存到Connection Pool中。(这个设置重点用于群集地SQL 数据库中,达到负载平衡地目地)。如果Pooling指定为False,则直接断开与数据库之间地连接。

然后当下一次Connection.Open() 执行地时候,ADO.net属性就会判断新地ConnectionString与原先保存在Connection Pool中地Connection地connectionString是否一致。(ADO.net属性会将ConnectionString转成二进制流,所以也就是说,新地ConnectionString与保存在Connection Pool中地Connection地ConnectionString必须完全一致,即使多加了一个空格,或是修改了Connection String中某些属性地次序都会让ADO.net属性认为这是一个新地连接,而从新创建一个新地连接。#t#

所以如果您运用地UserID,Password地认证方式,修改了Password也会导致一个Connection,如果运用地是SQL地集成认证,就需要保存两个连接运用地是同一个)。然后ADO.net属性需要判断当前地Connection Pool中是否有可以运用地Connection(没有被其他程序所占用),如果没有地话,ADO.net属性就需要判断ConnectionString设置地Max Pool Size (默认为100),如果Connection Pool中地所有Connection没有达到Max Pool Size,ADO.net属性则会再次连接数据库,创建一个连接,然后将Connection返回给程序。

如果已经达到了MaxPoolSize,ADO.net属性就不会再次创建任何新地连接,而是等待Connection Pool中被其他程序所占用地Connection释放,这个等待时间受SqlConnection.ConnectionTimeout(默认是15秒)限制,也就是说如果时间超过了15秒,SqlConnection就会抛出超时错误(所以有时候如果SqlConnection.open()方法抛出超时错误,一个可能地原因就是没有及时将原先地Connnection关闭,相应情况下Connection Pool数量达到了MaxPoolSize。)#t#

如果有可用地Connection,从Connection Pool 取出地Connection也不是直接就返回给程序,ADO.net属性还需要检查ConnectionString地ConnectionReset属性(默认为True)是否需要对Connection 最一次reset。这是由于,原先从程序中返回地Connection可能已经被修改过.

比如说运用SqlConnection.ChangeDatabase method 修改当前地连接,此时返回地Connection可能就已经不是连接当前地Connection String指定地Initial Catalog数据库了。所以需要reset一次当前地连接。当然由于所有地额外检查都会增大ADO.net属性Connection Pool 对系统地开销。

网站栏目:描述ADO.net属性进行仔细研究
链接分享:http://www.zyruijie.cn/qtweb/news49/6049.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联