ADO.NET中的Connection对象详解

   连接字符串

  连接字符串的几个常用参数:

  Provider:这个属性用于设置或返回连接提供程序的名称,仅用于OleDbConnection对象。

  Connection Timeout或Connect Timeout:在中止尝试并产生异常前,等待连接到服务器的连接时间长度(以秒为单位)。默认是15秒。

  Initail Catalog:数据库的名称。

  Data Source:连接打开时使用的sql server名称,或者是Microsoft Access数据库的文件名。

  Password:SQL Server帐户的登录密码。

  User ID:SQL Server登录帐户。

  Integrated Security或Trusted Connection:此参数决定是否是安全连接。可能的值有True、False和SSPI(SSPI是True的同义词)。

  Persist Security Info:当设置为False时,如果连接是打开的或曾经处于打开状态,那么安全敏感信息(如密码)不会作为连接的一部分返回。设置属性值为True可能有安全风险。False是默认值。

  1.写法一

  “Data Source=服务器名; Initial Catalog=数据库; User ID =用户名; Password=密码; Charset=UTF8; “

  2.写法二

  “Server=服务器名; Database=数据库; uid=用户名; Password=密码;Charser=UTF8″

  PS: Integrated Security = True;

  如果忘了连接字符串怎么写怎么办?(虽然挺丢人的)

  可以使用SqlConnectionStringBuilder生成字符串,如果忘了怎么写。

  MySqlConnectionStringBuilder可以用点出来你想要的属性。

  Connection需要释放

  Connection是实现了IDisposable接口的对象。使用Connection需要释放资源。

  建议用 using(Connection对象)

  {

  //自动Close(); 自动Dispose();

  }

  StateChange事件

  这个事件会监听数据库连接状态。当数据库连接状态改变时,就会触发这个操作。

  我们就可以进行一些操作。

  数据库连接状态是一个枚举,ConnectionState。

  目前为止ConnectionState一共有三个用的上值分别是

  Closed 连接处于关闭状态。

  Connecting 连接对象正在与数据源连接。

  Open 连接处于打开状态。

  连接池

  1.实验

  首先,在连接字符串中设置 pooling = false;

  然后通过

  StopWatch watch =new StopWatch( );

  watch.Start();

  //进行数据库操作。

  watch.Stop();

  输出watch.Elapsed;

  我们惊喜的返现,在连接字符串中设置了pooling = false以后,照原有性能下降了20~30倍。

  Connection对象提供了4种连接方式

  1、OLEDB :System.Data.Oledb.OledbConnection 对于非SQL Server和非Oracle数据库使用

  2、SQL:System.Data.SqlCilent.SqlConnection 用于连接SQL Server数据库

  3、ODBC:System.Data.Odbc.OdbcConnection 如果数据库没有内置的OLEDB,则可以使ODBC.NET数据提供者对象。

  4、Oracle:System.Data.OracleClient.OracleConnection 用于连接Oracle数据库

  为什么呢?

  我继续看,下一个实验。先把pooling = false删掉。

  用循环控制 Connection对象的关闭与打开。进行2000次吧。

  然后我们使用SqlServer【工具】→【SQL Server Profiler】。使用这个工具可以观察数据库事务、连接记录。

  我们发现2000次的 Open()/Close(),在SQL Server Profiler只查看到了一次数据库连接。

  而Pooling=false以后是实实在在的连接了2000次。

  做这两个实验的目的是为了引出一个知识点,即连接池。

  那么,现象有了,我们结下来看看原理。

  2.原理

  原理图


  Connection对象,第一次连接建立以后,Close时,并不是直接关闭,而是保存在连接池中。

  下次连接时,如果连接字符串相同,就调用连接池中的连接。而不是重新建立。

  这样会提高一定的效率。这一点在在实验一中验证过了。

  //1.销毁的是Conn对象,而连接池中的连接并没有销毁。

  //2.连接池是ADO.NET提供的,不是数据库的。在本地缓存中。

  3.第一次运行慢?

  .NET的程序为什么大多数第一次运行比较慢呢?

  即时编译固然是很重要一个原因。

  进行数据库操作时,ADO连接池是空的,也是一个原因!

时间: 2024-09-29 09:37:13

ADO.NET中的Connection对象详解的相关文章

java中Hibernate中的数据库对象详解

1.hibernate.cfg.xml  代码如下 复制代码 <!DOCTYPE hibernate-configuration PUBLIC         "-//Hibernate/Hibernate Configuration DTD 3.0//EN"         "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuratio

JavaScript中的Reflect对象详解(ES6新特性)_javascript技巧

Reflect介绍: Reflect这个对象在我的node(v4.4.3)中还没有实现, babel(6.7.7)也没有实现 ,新版本的chrome是支持的, ff比较早就支持Proxy和Reflect了,要让node支持Reflect可以安装harmony-reflect ; Reflect不是构造函数, 要使用的时候直接通过Reflect.method()调用, Reflect有的方法和Proxy差不多, 而且多数Reflect方法原生的Object已经重新实现了. 什么要使用Reflect

javascript中活灵活现的Array对象详解_javascript技巧

前言 JavaScript中的Array对象,就是我们常说的数组对象,主要用于封装多个任意类型的数据,并对它们进行管理. 所有主流浏览器均支持Array对象. 大家都知道Array实例有这四个方法:push.pop.shift.unshift.大家也都知道 push + pop实现栈, shift + push实现队列.在这里不讨论什么先进后出.先进先出. 但一面这个题将要用到这几个方法. 题目 螺旋矩阵这个名词,在后台语言中可能很熟悉,他是个二维数组,他有什么特点呢?请看下图: 以上是一个从外

&amp;#106avascript的document和window对象详解

window|对象|详解 [document对象] 该对象是window和frames对象的一个属性,是显示于窗口或框架内的一个文档. 属性 alinkColor 活动链接的颜色(ALINK) anchor 一个HTMI锚点,使用<A NAME=>标记创建(该属性本身也是一个对象) anchors array 列出文档锚点对象的数组(<A NAME=>)(该属性本身也是一个对象) bgColor 文档的背景颜色(BGCOLOR) cookie 存储于cookie.txt文件内的一段

JavaScript的document对象详解

javascript|对象|详解 1.对象属性document.title //设置文档标题等价于HTML的<title>标签document.bgColor //设置页面背景色document.fgColor //设置前景色(文本颜色)document.linkColor //未点击过的链接颜色document.alinkColor //激活链接(焦点在此链接上)的颜色document.vlinkColor //已点击过的链接颜色document.URL //设置URL属性从而在同一窗口打开

ASP内置对象详解之Application对象

application|对象|内置对象|详解 Application对象是个应用程序级的对象,用来在所有用户间共享信息,并可以在Web应用程序运行期间持久地保持数据. Application的属性: 方法如下: Application对象没有内置的属性,但是我们可以自行创建其属性. <% Application("属性名")=值 %> 其实大部分Application变量都 存放在Contents集合中,当你创建一个新的Application变量时,其实就是在Content

ASP内置对象详解之Request对象

request|对象|内置对象|详解 Request对象用于接受所有从浏览器发往你的服务器的请求内的所有信息. 集合 Request.ClientCertificate(key[SubField]) 所有客户证书的信息的集合.对于Key,该集合具有如下的关键字: Subject 证书的主题.包含所有关于证书收据的信息.能和所有的子域后缀一起使用. Issuer 证书的发行人.包含所有关于证书验证的信息.除了CN外,能和所有的子域后缀一起使用. VadidFrom 证书发行的日期.使用VBScri

ASP内置对象详解之Response对象

response|对象|内置对象|详解 Response对象用于向客户端浏览器发送数据,用户可以使用该对象将服务器的数据以HTML的格式发送到用户端的浏览器,它与Request组成了一对接收.发送数据的对象,这也是实现动态的基础.下面介绍它常用的属性和方法. 1.Buffer属性 该属性用于指定页面输出时是否要用到缓冲区,默认值为False.当它为True时,直到整个Active Server Page执行结束后才会将结果输出到浏览器上.如:<%Response.Buffer=True%>&l

ASP内置对象详解之Server对象

server|对象|内置对象|详解 Server对象是ASP中一个很重要的对象,许多高级功能都是靠它来完成的.它提供了对Active Server Pages对和方法的使用,在这我主要介绍几个常用的方法. 1.MapPath方法 该方法返回指定文件的相对路径或物理路径.若Path以一个(/)或(\)开始,则MapPath方法返回路径时将Path视为完整的虚拟路径.若Path不是以斜杠开始,则MapPath方法返回同.asp文件中已有的路径相对的路径.如:test.asp文件位于C:\inetpu