请注意,这个问题是我尚未解决的当前问题的一个分支:
当 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;
}