ADO.NET中的Connection详解
连接字符串
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详解的更多相关文章
- ADO.NET中的DataReader详解
使用特性 原理图 PS:Read()使指针下移,同时销毁上一条.所以SqlDataReader是只进的. GetValue()是找当前行中的列 SqlDataReader()特性. 1)只进的 上面 ...
- ADO.NET中的Command详解
Command方法介绍 1.ExecuteNonQuery 对于Update.Insert.Delete执行并返回受影响行数 对于其他语句返回 -1 2.ExecuteScalar 执行查询.并返回结 ...
- SqlHelper帮助类_上(SQLServer数据库含Connection详解)
在操作数据库时,经常会用到自己封装的SqlHelper.这里主要对SQLServer数据库的Sqlhelper,主要用于在同一个连接中完成CRUD! 一.ADO.NET中的Connection详解: ...
- (转)python标准库中socket模块详解
python标准库中socket模块详解 socket模块简介 原文:http://www.lybbn.cn/data/datas.php?yw=71 网络上的两个程序通过一个双向的通信连接实现数据的 ...
- ALSA声卡驱动中的DAPM详解之六:精髓所在,牵一发而动全身
设计dapm的主要目的之一,就是希望声卡上的各种部件的电源按需分配,需要的就上电,不需要的就下电,使得整个音频系统总是处于最小的耗电状态,最主要的就是,这一切对用户空间的应用程序是透明的,也就是说,用 ...
- php中关于引用(&)详解
php中关于引用(&)详解 php的引用(就是在变量或者函数.对象等前面加上&符号) 在PHP 中引用的意思是:不同的变量名访问同一个变量内容. 与C语言中的指针是有差别的.C语言中的 ...
- JavaScript正则表达式详解(二)JavaScript中正则表达式函数详解
二.JavaScript中正则表达式函数详解(exec, test, match, replace, search, split) 1.使用正则表达式的方法去匹配查找字符串 1.1. exec方法详解 ...
- AngularJS select中ngOptions用法详解
AngularJS select中ngOptions用法详解 一.用法 ngOption针对不同类型的数据源有不同的用法,主要体现在数组和对象上. 数组: label for value in a ...
- 【转载】C/C++中extern关键字详解
1 基本解释:extern可以置于变量或者函数前,以标示变量或者函数的定义在别的文件中,提示编译器遇到此变量和函数时在其他模块中寻找其定义.此外extern也可用来进行链接指定. 也就是说extern ...
随机推荐
- laravel项目return back()->withErrors($validator)或return back()->with('errors','原密码错误!')在前台原密码错误的情况下不能正确显示错误信息,变成报错!
被折磨的答案是 php artisan --version看一下版本,如果是5.2.26以上的,在路由处删除web中间件分组,还有问题再反馈
- Java多线程之DaemonThreadFactory
通过DaemonThreadFactory创建后台线程池 另外:如果是后台线程创建的线程,将都是后台线程. package wzh.daemon; import java.util.concurren ...
- (英文版)使用Visual Studio 2015 编写 MASM 汇编程序!
原文地址:http://kipirvine.com/asm/gettingStartedVS2015/index.htm#CreatingProject Getting Started with MA ...
- centos5安装在大硬盘上面的问题
硬盘空间大小: 3TB 原始硬盘是GPT格式的,系统安装现象如下: 此时按 ctrl + alt + F2 ,进入命令行界面,输入如下: 发现 用parted修改硬盘分区格式为msdos,报错!基本可 ...
- CRM 2016 自定义lookup过滤
function preFilterLookup() { //终端业态 Xrm.Page.getControl("new_typeofoperationid").addPreSea ...
- [原]iptables的NAT策略
#*nat #:PREROUTING ACCEPT [:] #:POSTROUTING ACCEPT [:] #:OUTPUT ACCEPT [:] # #-A PREROUTING –s IP1 - ...
- Html5——地理定位及地图
常用的navigator.geolocation对象有以下三种方法: 获取当前地理位置:navigator.geolocation.getCurrentPosition(success_callbac ...
- Redis多机功能之Sentinel
Sentinel的目的:监视主从服务器,并在主服务器下线时自动进行故障转移 启动Sentinel 通过执行Redis安装文件中的redis-sentinel程序,可以启动一个Sentinel实例: r ...
- redis学习(3)redis.conf配置文件详解
# Redis 配置文件 # 当配置中需要配置内存大小时,可以使用 1k, 5GB, 4M 等类似的格式,其转换方式如下(不区分大小写) # # 1k => 1000 bytes # 1kb ...
- [linux]查看文件编码和编码转换
方法一:file filename 方法二:在Vim中可以直接查看文件编码 :set fileencoding 即可显示文件编码格式. 如果你只是想查看其它编码格式的文件或者想解决用Vim查看文件乱码 ...