ADO.NET中的Connection对象详解

ADO.NET Connection对象代表与数据源的连接。在访问数据库时,首先创建一个ADO.NET Connection对象,通过它建立到数据库的连接。通常需要在头文件中定义一个VConnection对象。

连接字符串

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

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连接池是空的,也是一个原因!

网友评论
最新图文
  • ADO.NET中的Connection对象详解

    ADO.NET Connection对象代表与数据源的连接。在访问数据库时,首先创建一个ADO.NET Connection对象,通过它建立到数据库的连接。通常需要在头文件中定义一个VConnection对象。连接字符串连接字符串的几个常用参数:Provider:这个属性用于设置或返回连,西西hvbet688园-最安全的下载资讯站。

  • ASP.NET 缓存技术快速获取数据

    缓存是指系统或应用程序将频繁使用的数据保存到内存中,当系统或应用程序再次使用时,能构快速的获取数据。它的弊端在于显示的内容可能不是最新,最精确的ASP.Net 缓存主要分为两大类: 网页输出缓存和应用程序缓存&nbs,西西hvbet688园-最安全的下载资讯站。

  • AspNet MVC中各种上下文理解

    ASP.NET 是一个开发框架,用于通过 HTML、CSS、JavaScript 以及服务器脚本来构建网页和网站。MVC 是三个 ASP.NET 开发模型之一。MVC 是用于构建 web 应用程序的一种框架,使用 MVC (Model View Controller) 设计:Model(模型)表示应用程序核心(比如,西西hvbet688园-最安全的下载资讯站。

  • 在ASP.NET Web API中是如何实现跨域资源共享?

    在《通过扩展让ASP.NET Web API支持W3C的CORS规范》中,我们通过自定义的HttpMessageHandler自行为ASP.NET Web API实现了针对CORS的支持,实际上ASP.NET Web API自身也是这么做的,该自定义HttpMessageHandler就是System.Web.Http.Cors.CorsMessageHandler。,西西hvbet688园-最安全的下载资讯站。

  • ASP.NET中的Session怎么正确使用

    Session对象用于存储从一个用户开始访问某个特定的aspx的页面起,到用户离开为止,特定的用户会话所需要的信息。用户在应用程序的页面切换时,Session对象的变量不会被清除。 对于一个Web应用程序而言,所有用户访问到的Application对象的内容是完全一样的;而不同,西西hvbet688园-最安全的下载资讯站。