zoukankan      html  css  js  c++  java
  • [原]DataReader 处理多个结果集—NextResult的用法

    仔细查看您的数据库代码,看是否存在多次进入数据库的请求路径。每个这样的往返都会降低应用程序可以提供的每秒请求数量。通过在一个数据库请求中返回多个结果集,可以节省与数据库进行通信所需的总时间长度。同时因为减少了数据库服务器管理请求的工作,还会使得系统伸缩性更强。
    简单示例如下:

    一、返回多个数据集的存储过程
    CREATE PROC Proc ---Multiple Resultsets
    AS
    SELECT * FROM Users
    SELECT * FROM Users WHERE State = 'CA'
    GO

    二、取多个数据集的代码
       String ConnString  = "User ID=sa;password=sa;Initial Catalog=pubs;Data Source=myServer";
       SqlConnection Connection = new SqlConnection(myConnString);
       SqlCommand Command = new SqlCommand();
       SqlDataReader reader ;

       Command.CommandType = CommandType.StoredProcedure;
       Command.Connection = Connection;
       Command.CommandText = "Proc";
       int RecordCount=0;
       try
       {
        Connection.Open();
        reader = command.ExecuteReader();
        int RecordCount=0;

        // read the data from that resultset
        while (reader.Read())
        {
         RecordCount = RecordCount + 1;
        }
        Response.Write("Total number of Users:" + RecordCount.ToString());

        // read the next resultset
        reader.NextResult();
        RecordCount = 0;

        // read the data from that second resultset
        while (reader.Read())
        {
         RecordCount = RecordCount + 1;
        }
        Response.Write("Total number of Users from California:" + RecordCount.ToString());
       }
       catch (Exception ex)
       {
        MessageBox.Show(ex.ToString());
       }
       finally
       {
        Connection.Close();
       }

  • 相关阅读:
    2-SAT
    CDQ分治
    整体二分
    未完成
    [BZOJ1857][SCOI2010]传送带-[三分]
    [LCT应用]
    [胡泽聪 趣题选讲]大包子环绕宝藏-[状压dp]
    [清华集训2015 Day2]矩阵变换-[稳定婚姻模型]
    [清华集训2015 Day1]主旋律-[状压dp+容斥]
    [清华集训2015 Day1]玛里苟斯-[线性基]
  • 原文地址:https://www.cnblogs.com/skylaugh/p/444918.html
Copyright © 2011-2022 走看看