2

可以将 SqlDataReader 传递给会话或发送给客户端吗?

例如,如果我从数据库中检索了一些行,并希望将此数据发送到另一台客户端计算机。我可以通过在服务器上使用 json 对其进行序列化然后在客户端反序列化来简单地做到这一点吗?

4

4 回答 4

4

不,只能序列化数据(没有方法或功能),因此数据读取器将无用,因为您无法调用方法来推进读取器等。模式是将所有记录从阅读器,关闭它,然后将这些对象序列化回客户端。

于 2013-04-15T15:20:55.793 回答
2

不,您必须将阅读器映射到 POCO 并且将被序列化。即使您可以在技术上序列化 SqlDatReader 对象,这也是一个非常糟糕的主意。不要这样做。使用微规则将查询映射到 DTO 很简单。不要使你的工作复杂化。

于 2013-04-15T15:21:16.730 回答
2

不,任何与资源相关的对象都不能“传递”给客户端。

这真的没有意义。您应该“物化”数据读取器并传递结果。

即您可以从您的阅读器创建一个SqlDataAdapter,填充一个DataTable 并传递DataTable。

于 2013-04-15T15:20:38.687 回答
2

老问题,但技术提供了新的解决方案。

您可以使用Protocol Buffers DataReader Extensions for .NET来序列化 SqlDataReader,并且可以传递给会话或发送给客户端

例子:

      string connstring1 = "Data Source=server1;Initial Catalog=northwind;user=xxx;password=xxx";

        //Serializing an IDataReader into a ProtoBuf:

        Stream buffer = new MemoryStream();
        using (var c1 = new SqlConnection(connstring1))
        {
           c1.Open();
            // Serialize SQL results to a buffer
            using (var command = new SqlCommand("SELECT * FROM products", c1))
            using (var reader = command.ExecuteReader())
                DataSerializer.Serialize(buffer, reader);

            // Read them back
            buffer.Seek(0, SeekOrigin.Begin);
            using (var reader = DataSerializer.Deserialize(buffer))
            {
                while (reader.Read())
                {
                    Console.WriteLine(reader["ProductName"]);
                }
            }
        }

    }

你应该安装 nuget 包:

   Install-Package protobuf-net-data
于 2017-08-20T11:21:07.950 回答