点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)问候! 目前,我正在处理一位客...
点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)问候! 目前,我正在处理一位客...
加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)
问候!
目前,我正在处理一位客户的问题。 该问题是Crystal Report 2013内存不足的问题。 以下是问题的详细信息:
我们的客户针对中等大小的MS SQL Server数据库运行了3个月(最后一个季度)的报告。 他们遇到以下错误:
[错误] ReportViewer.RefreshReport:RunReport期间发生异常。 Cancelled = False
最高例外
Type = System.Runtime.InteropServices.COMException
Source = rptcontrollers.dll
Message = 没有足够的内存用于操作。
StackTrace:
at CrystalDecisions.ReportAppServer.Controllers.ReportSourceClass.GetLastPageNumber(RequestContext pRequestContext)
at CrystalDecisions.ReportSource.EromReportSourceBase.GetLastPageNumber(ReportPageRequestContext reqContext)
,位于CrystalDecisions.CrystalReports.Engine.FormatEngine.GetLastPageNumber(ReportPageRequestContext reqContext)
d中的ININ.Reporting.Historical.Engine.Module.ViewModels.CrystalReportsViewerControl.RunReport()上的cs:125行
在System.Threading.Tasks.Task`1.InnerInvoke()
在System.Threading.Tasks.Task.Execute()
StackTrace:
在<> c__DisplayClass16。 em>
at AggregateException.Handle(Func`2谓词)
在ReportViewer。
在Task.Execute()上
在Task.ExecutionContextCallback(Object obj)
在ExecutionContext.RunInternal(ExecutionContext执行上下文,ContextCallback回调,对象状态,布尔值saveSyncCtx)
在ExecutionContext.Run(ExecutionContext执行上下文,ContextCallback回调,对象状态,布尔值saveSyncCtx)
在Task.ExecuteWithThreadLocal(Task&currentTaskSlot)
在Task.ExecuteEntry(布尔值bPreventDoubleExecution)
在SynchronizationContextTaskScheduler.PostCallback(Object obj)
在ExceptionWrapper.InternalRealCall(委托回调,对象args,Int32 numArgs)
在ExceptionWrapper.TryCatchWhen(对象源,委托回调,对象args,Int32 numArgs,委托catchHandler)
在DispatcherOperation.InvokeImpl()
在DispatcherOperation.InvokeInSecurityContext(对象状态)
在ExecutionContext.RunInternal(ExecutionContext执行上下文,ContextCallback回调,对象状态,布尔值saveSyncCtx)
在ExecutionContext.Run(ExecutionContext执行上下文,ContextCallback回调,对象状态,布尔值saveSyncCtx)
在ExecutionContext.Run(ExecutionContext执行上下文,ContextCallback回调,对象状态)
在CulturePreservingExecutionContext.Run(CulturePreservingExecutionContext执行上下文,ContextCallback回调,对象状态)
在DispatcherOperation.Invoke()
在Dispatcher.ProcessQueue()
在Dispatcher.WndProcHook(IntPtr hwnd,Int32 msg,IntPtr wParam,IntPtr lParam,布尔值和已处理)
HwndWrapper.WndProc中的(IntPtr hwnd,Int32 msg,IntPtr wParam,IntPtr lParam,布尔值和已处理)
HwndSubclass.DispatcherCallbackOperation(Object o)上的
在ExceptionWrapper.InternalRealCall(委托回调,对象args,Int32 numArgs)
在ExceptionWrapper.TryCatchWhen(对象源,委托回调,对象args,Int32 numArgs,委托catchHandler)
位于Dispatcher.LegacyInvokeImpl(DispatcherPriority优先级,TimeSpan超时,Delegate方法,对象args,Int32 numArgs)
HwndSubclass.SubclassWndProc上的(IntPtr hwnd,Int32 msg,IntPtr wParam,IntPtr lParam)
在UnsafeNativeMethods.DispatchMessage(MSG&msg)
在Dispatcher.PushFrameImpl(DispatcherFrame frame)
在Dispatcher.PushFrame(DispatcherFrame frame)
在Application.RunDispatcher(对象忽略)
在Application.RunInternal(窗口窗口)
在Application.Run(窗口窗口)
at WpfShellImplementation.ShowAndRun()d:\ builds \ eic_main_systest \ products \ eic \ src\ Cafe \ Library.Wpf \ WpfShellImplementation.cs(72)
CafeApplication.Run()上的d:\ builds \ eic_main_systest \ products \ eic \ src\ Cafe \ Library \ CafeApplication.cs(203)
在ShellApplication.RunApp()
在ShellApplication.Main()
我们也可以使用其数据库在本地测试环境中重现该问题。 我们已经用16 GB的内存测试了该报告,但是运行Crystal Report的应用程序在可用内存下就很好了。
我们还测试了数据库查询,结果如下:
进一步调查该问题,我们尝试搜索有关该错误的一些内容,发现此链接表明,作为32位应用程序,Crystal Report在任何给定时间点只能访问大约2GB的RAM。 我们的Crystal Report版本是13.0.9.1312:
无法运行的报告具有不同组的聚合/求和公式。 如果运行时间较短(<30天),则此报告运行良好。
CR2013在处理具有不同组的聚合/求和公式的大数据集时是否有任何限制? 感谢您为解决此问题提供的帮助。
谢谢!
Sanjoy。
Hi Don, >
感谢补丁详细信息。 我已将补丁升级到最新版本:
很遗憾,现在没有报告在运行。 CR本身会引发以下错误:
[错误] ReportViewer.RefreshReport:顶级异常类型= System.Runtime.InteropServices.COMException源= clientdoc.dll消息=文档尚未打开。 StackTrace:位于CrystalDecisions.ReportAppServer.ReportClientDocumentWrapper.set_ReportAppServer(String值)的CrystalDecisions.ReportAppServer.ClientDoc.ReportClientDocumentClass.set_ReportAppServer(String pbsVal)的CrystalDecisions.CrystalReports.Engine.ReportDocument.Initialize()的CrystalDecisions.CrystalReports.Engine。 d:\ builds \ eic_main_systest \ products \ eic \ src\ reporting \ HistoricalReporting \ ReportEngine \ ReportEngineModule \ Views中的ININ.Reporting.Historical.Engine.Module.ViewModels.CrystalReportsViewerControl..ctor中的ctor(ReportData reportData,CancellationTokenSource tokenSource) \ CrystalReportsViewerControl.cs:第29行位于ININ.Reporting.Historical.Engine.Module.ViewModels.ViewerControl.GetViewerControl(ReportData reportData,CancellationTokenSource tokenSource,Action refreshAction)在d:\ builds \ eic_main_systest \ products \ eic \ src\ reporting \ HistoricalReporting \ ReportEngine \ ReportEngineModule \ ViewModels \ ViewerControl.cs:ININ.Reporting.Historical的第39行。 d:\ builds \ eic_main_systest \ products \ eic \ src\ reporting \ HistoricalReporting \ ReportEngine \ ReportEngineModule \ ViewModels \ ReportViewer.cs:line 511 StackTrace:在ReportViewer.RefreshReport()d中的Engine.Module.ViewModels.ReportViewer.RefreshReport() :\ Builds \ eic_main_systest \ products \ eic \ src\ reporting \ HistoricalReporting \ ReportEngine \ ReportEngineModule \ ViewModels \ ReportViewer.cs(583)at ReportViewer.SwitchReportView()d:\ builds \ eic_main_systest \ products \ eic \ src\ reporting \ HistoricalReport 在ReportViewer.Execute处的\ ReportEngine \ ReportEngineModule \ ViewModels \ ReportViewer.cs(207)(字符串commandName,Object context)d:\ builds \ eic_main_systest \ products \ eic \ src\ reporting \ HistoricalReporting \ ReportEngine \ ReportEngineModule \ ViewModels \ ReportViewer.cs (967)在ReadOnlyContextSensitiveCommandsProvider.Execute(String commandName,Object context)d:\ builds \ eic_main_systest \ products \ eic \ src\ Cafe \ Library \ Commands \ SupportedOperations.cs(101)在AssociatedWithActiveContentViewBehavior.Execute(ICommandItem因此 urceCommandItem,对象上下文)d:\ Builds \ eic_main_systest \ products \ eic \ src\ Cafe \ Interface \ Content \ ContentBehaviors.cs(639)at CommandItem.ININ.Cafe.Interface.Commands.ICommandItem.ExecuteCommand(Object context)d: \ builds \ eic_main_systest \ products \ eic \ src\ Cafe \ Library \ Commands \ CommandItem.cs(352)在CommandItem.ININ.Cafe.Library.Commands.ICommandExecutorInternal.ExecuteCommand(Object context)d:\ builds \ eic_main_systest \ products \ WpfUISite.System.Windows.Input.ICommand.Execute上的eic \ src\ Cafe \ Library \ Commands \ CommandItem.cs(364)(Object param)d:\ builds \ eic_main_systest \ products \ eic \ src\ Cafe \ Library.Wpf \ Commands \ UISites \ Wpf \ Controls \ WpfUISite.cs(309)在CommandHelpers.CriticalExecuteCommandSource(ICommandSource commandSource,Boolean userInitiated)在ButtonBase.OnClick()在Button.OnClick()在ButtonBase.OnMouseLeftButtonUp(MouseButtonEventArgs e)在UIElement.OnMouseLeftButtonUpThunk (Object sender,MouseButtonEventArgs e)在MouseButtonEventArgs.InvokeEventHandler(Delegate genericHandl) er,在RoutedEventArgs.InvokeHandler(代理处理程序,对象目标)处的对象GenericTarget)在EventRoute.InvokeHandlersImpl(对象源,RoutedEventArgs args,布尔值重新引发)处的RoutedEventHandlerInfo.InvokeHandler(对象目标,RoutedEventArgs routedEventArgs),在UIElement.ReRaiseEvents,Send args,UIElement.OnMouseUpThunk(Object sender,MouseButtonEventArgs e)处的RoutedEvent newEvent)在RoutedEventArgs.InvokeHandler(Delegate handler,Object target)在RoutedEventHandlerInfo.InvokeHandler(Delegate handler,Object target)处在MouseButtonEventArgs.InvokeEventHandler(Delegate genericHandler,Object genericTarget)中 UIElement处的EventRoute.InvokeHandlersImpl(Object source,RoutedEventArgs args,Boolean reRaised)UIElement.RaiseTrustedEvent(RoutedEventArgs args)处的UIElement.RaiseTrustedEvent(RoutedEventArgs args)处的UIElement.RaiseEvent(RoutedEventArgs args,布尔值受信任的) 输入项 HwndMouseInputProvider.FilterMessage(IntPtr)的Manager.ProcessInput(InputEventArgs输入)在HwndMouseInputProvider.ReportInput(IntPtr hwnd,InputMode模式,Int32时间戳,RawMouseActions操作,Int32 x,Int32 y,Int32滚轮)在InputProviderSite.ReportInput(InputReport inputReport) 在HwndSource.InputFilterMessage(IntPtr hwnd,Int32 msg,IntPtr wParam,IntPtr lParam,布尔值和处理)处的msg,IntPtr wParam,IntPtr lParam,布尔值和已处理)在HwndWrapper.WndProc(IntPtr Hwnd,IntPtr wwnd, )在HwndSubclass.DispatcherCallbackOperation(Object o)在ExceptionWrapper.InternalRealCall(Delegate回调,Object args,Int32 numArgs)在ExceptionWrapper.TryCatchWhen(对象源,委托回调,Object args,Int32 numArgs,DelevatchHandler优先级在DispatcherIl ,TimeSpan超时,委托方法,对象参数,Int32 numArgs)位于HwndSubclass.SubclassWndProc(IntPtr hwnd,Int32 msg,IntP 在UnsafeNativeMethods.CallWindowProc(IntPtr wndProc,IntPtr hWnd,Int32 msg,IntPtr wParam,IntPtr lParam)处的tr wParam,IntPtr lParam)在NativeWindow.DefWndProc(Message&m)处的Int32 msg,IntPtr wParam,IntPtr lParam)。 at NativeWindow.Callback(IntPtr hWnd,Int32 msg,IntPtr lparam,IntPtr lparam)在NativeWindow.DefWndProc(Message&m)在NativeWindow.WndProc(Message&m)在NativeWindow.Callback(IntPtr hWnd,Int32 msg,IntPtr wparam,IntPtr lparam) WpfShellImplementation处的UnsafeNativeMethods.DispatchMessage(MSG&msg)处的Dispatcher.PushFrameImpl(DispatcherFrame框架)Dispatcher.PushFrame(DispatcherFrame框架)Application.RunDispatcher(对象ignore)处Application.RunInternal(Window窗口) .ShowAndRun()d:\ builds \ eic_main_systest \ products \ eic \ src\ Cafe \ Library.Wpf \ WpfShellImplementation.cs(72)at CafeApplication.Run()d:\ builds \ eic_main_systest \ products \ eic \ src\ Cafe \ S处的Library \ CafeApplication.cs(203) ShellApplication.Main()处的hellApplication.RunApp()
我想念什么吗?
谢谢!
Sanjoy。
一周热门 更多>