Dapper QueryMultiple 多结果集 遍历

得出这段代码的探索过程相当纠结。

代码如下:

class Program
    {

        //创建连接对象
        protected static SqlConnection GetConnection()
        {
            var connection = new SqlConnection("Data Source=.;Initial Catalog=TestDB;Integrated Security=True");
            connection.Open();
            return connection;
        }

        static void Main(string[] args)
        {
            //测试输出多个结果集
            var sql = @"INSERT INTO [dbo].[Student] ([Name]) VALUES ('A1'); select @@IDENTITY as A;
                        INSERT INTO [dbo].[Student] ([Name]) VALUES ('B1'); select @@IDENTITY as A;
                        INSERT INTO [dbo].[Student] ([Name]) VALUES ('C1'); select @@IDENTITY as A";

            //初始化数据库连接
            using (SqlConnection connection = GetConnection())
            {                
                List<int> ilist = new List<int>();
                //执行查询,获取结果集集合
                var multi = connection.QueryMultiple(sql);

                //遍历结果集
                while(!multi.IsConsumed)
                {
                    //读取当前结果集
                    var result = multi.Read().ToList()[0].A;
                    if (result != null)
                    {
                        ilist.Add(Convert.ToInt32(result));
                    }
                }
                //for(int i = 0;i<3;i++)
                //{
                //    var result = multi.Read().ToList()[0].A;
                //    if (result != null)
                //    {
                //        ilist.Add(Convert.ToInt32(result));
                //    }
                //}
                foreach (var item in ilist)
                {
                    Console.WriteLine(item.ToString());
                }
            }
            Console.ReadLine();
        }
    }
高清截图如下:



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值