请注意,这个问题是我尚未解决的当前问题的一个分支:
当 WCF 服务返回 DataTable: OutOfMemoryException 时需要帮助解决错误
我有一个现有的 WCF 服务,其端点配置为TransferMode.Buffered
和一个客户端应用程序,其连接要求相同。
OperationContracts
除了非常小的方式外,我无法轻易修改这些已建立的方法。例如,我们有一个接受 SQL 查询String
并返回DataTable
从 SQL 执行派生的方法。
我们在使用这种方法时遇到了非常大的表的问题。大意味着内存占用。
我正在考虑实施TransferMode.Streamed
(或类似的),但我似乎无法掌握如何仅针对某些方法执行此操作。
我的 WCF 服务启动,创建了唯一的端点,该端点是Buffered
. 所以这使我们想要假设它是全部或全部。如果我改成那样,我将不得不对我所有的方法Streaming
进行大规模的返工。OperationContract
有一些 SO 问题与这个主题有关,但不是直接的,也没有任何真正让我到达我需要去的地方的答案。
我错过了什么,还是可以使它起作用?
我需要修复的方法:(如果您想了解连接,请参考引用的问题...代码很多)
WCF 服务代码:
[OperationContract]
DataTable readDataTable(out DbError dbError, String queryString, Boolean SchemaOnly);
public DataTable readDataTable(out DbError dbError, String queryString, Boolean SchemaOnly)
{
DataTable dt = new DataTable("ReturnTable");
dbError = new DbError();
if (!String.IsNullOrEmpty(queryString))
{
try
{
command.CommandText = queryString.Replace(new String[] { "{{", "}}", ";;" }, new String[] { "{", "}", ";" });
SqlDataReader reader = command.ExecuteReader(SchemaOnly ? CommandBehavior.SchemaOnly : CommandBehavior.Default);
dt.Load(reader);
reader.Close();
}
catch (Exception ex)
{
dbError.HasError = true;
dbError.Error = ex.Message + "\n\n" + queryString;
}
}
return dt;
}
使用它的客户端代码:
public DataTable readDataTable(String queryString, Boolean SchemaOnly)
{
DbError dbError;
DataTable dt = svcCon.readDataTable(out dbError, queryString, SchemaOnly);
if (dbError.HasError)
{
if (_showErrors)
ErrorHandler.Show(dbError.Error);
}
return dt;
}