Datareader 执行动态计算

Posted

技术标签:

【中文标题】Datareader 执行动态计算【英文标题】:Datareader perform dynamic calculation 【发布时间】:2015-11-05 10:30:05 【问题描述】:

我正在尝试读取和处理大数据结果。我正在使用数据阅读器逐条读取项目记录,但是我需要在我的流程中处理计算。为了处理我将创建的名为“Name”的动态字段的示例,将从数据读取器 FirstName + " " + LastName 获取结果。

谁能帮助指导我让它工作。我不确定如何达到我想要的结果。

【问题讨论】:

【参考方案1】:

将计算放入您的 SQL 中。

SELECT *, FirstName + ' ' + LastName AS FullName
FROM   table
WHERE  where-clause
ORDER BY order-by-clause

解决@JoelCoehoorn 的担忧: 对于那些绝对必须在 C# 中执行此操作的人:

在 SqlDataReader 的循环中添加:

string fullName = reader["FirstName"] + " " + reader["LastName"];

或者如果您使用的是最新的 C#(VS2015 及更高版本):

string fullName = $"reader["FirstName"] reader["LastName"]";

【讨论】:

这几乎可以肯定是最简单和最快的答案(+1!),但如果您需要真正扩大规模,您通常会在客户端/C# 端做得更好。 同意。我想,当有人达到巨大的规模时,他们已经知道了。 我正在使用 VS2013,我无法执行该方法,因为计算是基于用户输入的动态计算。我需要让这个部分是动态的: reader["FirstName"] + " " + reader["LastName"]; 它的你的代码,@Paul。您可以根据需要将其设为“动态”或毫无生气。

以上是关于Datareader 执行动态计算的主要内容,如果未能解决你的问题,请参考以下文章

DataRead 和DataSet区别

Asp.net常用开发方法之DataTable/DataReader转Json格式代码

DataReader和DataSet的异同

c#dataread 读取数据库decimal类型的字段值

在 DataReader 中查看更新

如何计算 MySqlDataReader 中的行数?