连接字符串

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倍。

为什么呢?

我继续看,下一个实验。先把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详解的更多相关文章

  1. ADO.NET中的DataReader详解

    使用特性 原理图 PS:Read()使指针下移,同时销毁上一条.所以SqlDataReader是只进的. GetValue()是找当前行中的列 SqlDataReader()特性. 1)只进的  上面 ...

  2. ADO.NET中的Command详解

    Command方法介绍 1.ExecuteNonQuery 对于Update.Insert.Delete执行并返回受影响行数 对于其他语句返回 -1 2.ExecuteScalar 执行查询.并返回结 ...

  3. SqlHelper帮助类_上(SQLServer数据库含Connection详解)

    在操作数据库时,经常会用到自己封装的SqlHelper.这里主要对SQLServer数据库的Sqlhelper,主要用于在同一个连接中完成CRUD! 一.ADO.NET中的Connection详解: ...

  4. (转)python标准库中socket模块详解

    python标准库中socket模块详解 socket模块简介 原文:http://www.lybbn.cn/data/datas.php?yw=71 网络上的两个程序通过一个双向的通信连接实现数据的 ...

  5. ALSA声卡驱动中的DAPM详解之六:精髓所在,牵一发而动全身

    设计dapm的主要目的之一,就是希望声卡上的各种部件的电源按需分配,需要的就上电,不需要的就下电,使得整个音频系统总是处于最小的耗电状态,最主要的就是,这一切对用户空间的应用程序是透明的,也就是说,用 ...

  6. php中关于引用(&)详解

    php中关于引用(&)详解 php的引用(就是在变量或者函数.对象等前面加上&符号) 在PHP 中引用的意思是:不同的变量名访问同一个变量内容. 与C语言中的指针是有差别的.C语言中的 ...

  7. JavaScript正则表达式详解(二)JavaScript中正则表达式函数详解

    二.JavaScript中正则表达式函数详解(exec, test, match, replace, search, split) 1.使用正则表达式的方法去匹配查找字符串 1.1. exec方法详解 ...

  8. AngularJS select中ngOptions用法详解

    AngularJS select中ngOptions用法详解   一.用法 ngOption针对不同类型的数据源有不同的用法,主要体现在数组和对象上. 数组: label for value in a ...

  9. 【转载】C/C++中extern关键字详解

    1 基本解释:extern可以置于变量或者函数前,以标示变量或者函数的定义在别的文件中,提示编译器遇到此变量和函数时在其他模块中寻找其定义.此外extern也可用来进行链接指定. 也就是说extern ...

随机推荐

  1. Maven依赖(转)

    相同依赖级别,先加入的先依赖不同依赖级别,级别短的先依赖 version-->SNAPSHOTxxx-里程碑-->SNAPSHOT,alpha,beta,Release(RC),GA()s ...

  2. Gatling的进阶一

    转载:http://www.51testing.com/html/10/26810-852966.html 首先 抄袭一个Gatling的介绍 Gatling是一款基于Scala 开发的高性能服务器性 ...

  3. dede上怎么让所有链接在新窗口打开

    网页的头部,添加:<base target="_blank"> <base target="_blank"> </head> ...

  4. NLog文章系列——如何配置NLog

    NLog支持以多种不同方式配置,目前同时支持直接编程和使用配置文件两种方法.本文将对目前支持的各种配置方式作详细描述. 日志配置 通过在启动的时候对一些常用目录的扫描,NLog会尝试使用找到的配置信息 ...

  5. [ActionScript 3.0] AS3.0 获取文本的明暗度

    /** * 获取文字的明暗值 * @param t 文字 * @return Number */ function getDensity(t:String):Number { var ttf:Text ...

  6. Java SE 第二十三讲----static关键字and final关键字

    1.static关键字 [在二十二讲视频中30分钟开始讲授] 2.static修饰属性:无论一个类生成了多少个对象,所有这些对象共同使用唯一一份静态的成员变量:一个对象对该静态成员变量进行了修改,其他 ...

  7. [HDU 5074] Hatsune Miku (动态规划)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5074 题目大意是给你m个note,n个数,得分是v[a[i]][a[i+1]]的总和,如果说a[i]是 ...

  8. Java是传值还是传引用

    http://www.bccn.net/Article/kfyy/java/jszl/200601/3069.html 对于基本数据类型(整型.浮点型.字符型.布尔型等),传值;对于引用类型(对象.数 ...

  9. (转)C# SSL-X509使用

    X.509 给出的鉴别框架是一种基于公开密钥体制的鉴别业务密钥管理.一个用户有两把密钥:一把是用户的专用密钥(简称为:私钥),另一把是其他用户都可得到和利用的公共密钥(简称为:公钥).该鉴别框架允许用 ...

  10. HTTP 500 的解决方案

    我们首先要确定IIS权限的问题,如下所示: 身份验证的具体项: 身份验证的基本设置: 注意:如果不需要Form验证的情况下,那么把Form身份验证禁止掉,否则会出现在每一次请求的过程中都要有一个默认的 ...