zoukankan      html  css  js  c++  java
  • MultipleActiveResultSets=true 数据库连接复用

    注:EF连接Mysql时,连接字符串是不能包含MARS的,Mysql不支持这个特性。

    ADO.NET 1.n 利用SqlDataReader读取数据,针对每个结果集需要一个独立的连接。

    这些独立的链接也要占用相应的内存,在应用程序运行中还会形成高度拥挤的瓶颈效应。

    ADO.NET 2.的一个新特征多数据结果集(Multiple Active Result Sets,简称MARS)

    它允许在单个连接上执行多重的数据库查询或存储过程。目前只适用于Sql Server 2005

    在一个Command对象上同时打开多个DataReader,即可以在sqldatareader里面嵌套sqldatareader,

    如果不用MultipleActiveResultSets ,则一般报错为sqldatareader未关闭,即需要关闭了之后才能打开另一个

    使用方法:在数据库链接字符串后面加上MultipleActiveResultSets=true

    例如:string connstr = "server=(local);database=northwind;integrated security=true;MultipleActiveResultSets=true";

    MultipleActiveResultSets可以使数据库连接复用。这样就不怕数据库的连接资源被耗尽了。使用方法很简单,只需要把它加到数据的连接字符串中即可。

    例如:server=(local);Integrated Security = true;database=AdventureWorks;MultipleActiveResultSets=true;

    using System;  
    using System.Threading;  
    using System.Data.SqlClient;  
    using System.Configuration;  
      
    namespace ConsoleApplication1  
    {  
        public class Example  
        {  
            public static void Main()  
            {  
            SqlConnection sql1 = new SqlConnection("server=(local);Integrated Security = true;database=AdventureWorks;");  
                sql1.Open();  
                SqlCommand comm1 = new SqlCommand();  
                comm1.CommandText = "select 1";  
                comm1.CommandType = System.Data.CommandType.Text;  
            comm1.Connection = sql1;  
                comm1.ExecuteNonQuery();  
                sql1.Close();  
                Console.ReadLine();  
            }  
        }  
    }  

    编译后,打开bin/debug/ConsoleApplication1.exe。

    在SQL Server 2008 Management Studio中打开一个新窗口,输入sp_who

    按F5执行,可以发现已经有一个用户连接到AdventureWorks数据库了。

    再打开一个ConsoleApplication1.exe,发现又会多一个用户连接到AdventureWorks数据库。

    现在把程序的连接字符串改为server=(local);Integrated Security = true;database=AdventureWorks;MultipleActiveResultSets=true;

    按上面的顺序执行,发现不管打开多少个ConsoleApplication1.exe,数据库中没有用户或只有一个用户连接着AdventureWorks数据库。

    这就是数据库连接复用的好处了。

  • 相关阅读:
    [转]PHP如何关闭notice级别的错误提示
    [原]php远程odbc连接sqlsvr数据库,自定义端口,命名实例的连接方式
    [原] wmic: Invalid XSL format (or) file name错误解决方法
    [转]PHP Session的一个警告
    [转]权限问题导致Nginx 403 Forbidden错误的解决方法
    [转]require(),include(),require_once()和include_once()区别
    [转]Mysql命令行常用操作
    php读取sql2000的image字段,被截断的问题
    一、基于hadoop的nginx访问日志分析---解析日志篇
    shell判断条件整理
  • 原文地址:https://www.cnblogs.com/icebutterfly/p/9254521.html
Copyright © 2011-2022 走看看