Я работаю над приложением, основанным на другом приложении, и оба основаны на Telerik OpenAccess для чтения базы данных SQL-Server.
Регулярно мой клиент сталкивается со следующим исключение:
Telerik.OpenAccess.OpenAccessException: Change operation canceled by user.
at OpenAccessRuntime.ExceptionWrapper.Throw()
at OpenAccessRuntime.DataObjects.PCStateMan.handleException(Exception x)
at OpenAccessRuntime.DataObjects.PCStateMan.SetField[T](PersistenceCapable _pc, Int32 field, T currentValue, T newValue)
at App1.Server.Core.Domain.CommandOrderPart.OpenAccessEnhancedSet_status(CommandOrderPart owner, OrderStatus value)
at App1.Server.Core.Domain.CommandOrderPart.set_Status(OrderStatus value)
at App2.Helpers.ExtensionMethods.SetStatus(CommandOrderPart orderPart, String status) in C:\Source1.cs:line 47
at App2.Manager.RequestOrderStatus(JbtOrder order) in C:\Source2.cs:line 668
Telerik.OpenAccess.OpenAccessException: Change operation canceled by user.
at OpenAccessRuntime.ExceptionWrapper.Throw()
at OpenAccessRuntime.DataObjects.PCStateMan.handleException(Exception x)
at OpenAccessRuntime.DataObjects.PCStateMan.SetField[T](PersistenceCapable _pc, Int32 field, T currentValue, T newValue)
at App1.Server.Core.Domain.CommandOrderPart.OpenAccessEnhancedSet_status(CommandOrderPart owner, OrderStatus value)
at App1.Server.Core.Domain.CommandOrderPart.set_Status(OrderStatus value)
at App2.Helpers.ExtensionMethods.SetStatus(CommandOrderPart orderPart, String status) in C:\Source1.cs:line 47
at App2.Manager.RequestOrderStatus(JbtOrder order) in C:\Source2.cs:line 668
Что именно означает «Операция изменения отменена пользователем»? Хорошо, я понимаю, что мои приложения хотят установить статус (который является «операцией изменения»), но кто является пользователем, создающим это исключение? Могу ли я получить дополнительную информацию из базы данных? Какая таблица, представление или диагностика? ...?
декомпиляция Telerik OpenAccess DLL**
После декомпиляции Telerik OpenAccess DLL я обнаружил два случая отмены операции изменения пользователем< /code>:
/// Raises the Changing event.
/// Not intended for application use.
///
The event to raise.
public void FireChanging(ChangeEventArgs ev)
{
if (this.evChanging == null)
return;
this.evChanging(this.owner, ev);
if (ev.Cancel)
throw new OpenAccessException("Change operation canceled by user.", true);
}
PcStateMan.cs:
В «PcStateMan.cs» в handleException(...) можно увидеть следующее:
private void handleException(Exception x)
{
if (BindingSupportImpl.Instance.isOwnException(x))
throw new ExceptionWrapper(x).Throw();
throw BindingSupportImpl.Instance.internally(x.Message, x).Throw();
}
Это означает, что условие BindingSupportImpl.Instance.isOwnException(x) истинно (что бы это ни значило). Изменить: тайм-аут тайм-аута БД приложения:
Если настроен тайм-аут для App1 и/или App2, это может произойти (просто представьте, что App1.....CommandOrderPart.Set() занимает слишком много времени, в то время как App2 имеет настройку тайм-аута базы данных, это уже может вызвать проблему). Где я могу найти эти настройки таймаута? Редактировать: предложение найти SQL-оператор, вызывающий такую ситуацию
По-видимому, проблема возникает при изменении статуса App1.....CommandOrderPart. Можно создать SQL-трассировку, отслеживающую все транзакции, выполняемые с этим объектом, следующим образом:
Очевидно, я начинаю выполнение этого SQL-скрипта до шага 4. Если я хочу, чтобы сценарий остановился, я запускаю шаг 5.
Ну, раньше Я забыл: сценарий, который я впервые нашел, содержал другие значения для событий. Я выполнил SQL-запрос SELECT @@VERSION и в результате получился Microsoft SQL Server 2017 (RTM-CU31-GDR) (KB5029376)..., я решил зайти на эту страницу, чтобы получить определения событий:
Я работаю над приложением, основанным на другом приложении, и оба основаны на Telerik OpenAccess для чтения базы данных SQL-Server. Регулярно мой клиент сталкивается со следующим исключение: [code]Telerik.OpenAccess.OpenAccessException: Change operation canceled by user. at OpenAccessRuntime.ExceptionWrapper.Throw() at OpenAccessRuntime.DataObjects.PCStateMan.handleException(Exception x) at OpenAccessRuntime.DataObjects.PCStateMan.SetField[T](PersistenceCapable _pc, Int32 field, T currentValue, T newValue) at App1.Server.Core.Domain.CommandOrderPart.OpenAccessEnhancedSet_status(CommandOrderPart owner, OrderStatus value) at App1.Server.Core.Domain.CommandOrderPart.set_Status(OrderStatus value) at App2.Helpers.ExtensionMethods.SetStatus(CommandOrderPart orderPart, String status) in C:\Source1.cs:line 47 at App2.Manager.RequestOrderStatus(JbtOrder order) in C:\Source2.cs:line 668 Telerik.OpenAccess.OpenAccessException: Change operation canceled by user. at OpenAccessRuntime.ExceptionWrapper.Throw() at OpenAccessRuntime.DataObjects.PCStateMan.handleException(Exception x) at OpenAccessRuntime.DataObjects.PCStateMan.SetField[T](PersistenceCapable _pc, Int32 field, T currentValue, T newValue) at App1.Server.Core.Domain.CommandOrderPart.OpenAccessEnhancedSet_status(CommandOrderPart owner, OrderStatus value) at App1.Server.Core.Domain.CommandOrderPart.set_Status(OrderStatus value) at App2.Helpers.ExtensionMethods.SetStatus(CommandOrderPart orderPart, String status) in C:\Source1.cs:line 47 at App2.Manager.RequestOrderStatus(JbtOrder order) in C:\Source2.cs:line 668 [/code] Что именно означает «Операция изменения отменена пользователем»? Хорошо, я понимаю, что мои приложения хотят установить статус (который является «операцией изменения»), но кто является пользователем, создающим это исключение? Могу ли я получить дополнительную информацию из базы данных? Какая таблица, представление или диагностика? ...? декомпиляция Telerik OpenAccess DLL** После декомпиляции Telerik OpenAccess DLL я обнаружил два случая отмены операции изменения пользователем< /code>: [list] [*]Файл «DisconnectedStateManager.cs»: [/list] [code] private ChangeEventArgs FireChanging( object pc, int field, object oldV, object newV) { ChangeEventArgs ev = new ChangeEventArgs(pc, this.cmd.getFieldName(field), oldV, newV, this.state == (short) 4, true); this.repository.tracker.FireChanging(ev); return !ev.Cancel ? ev : throw new OpenAccessException("Change operation canceled by user.", true); } [/code] [list] [*]Файл ".../SPI/TrackingImpl.cs": [/list] [code] /// Raises the Changing event. /// Not intended for application use. /// The event to raise. public void FireChanging(ChangeEventArgs ev) { if (this.evChanging == null) return; this.evChanging(this.owner, ev); if (ev.Cancel) throw new OpenAccessException("Change operation canceled by user.", true); } [/code] PcStateMan.cs: В «PcStateMan.cs» в handleException(...) можно увидеть следующее: [code] private void handleException(Exception x) { if (BindingSupportImpl.Instance.isOwnException(x)) throw new ExceptionWrapper(x).Throw(); throw BindingSupportImpl.Instance.internally(x.Message, x).Throw(); } [/code] Это означает, что условие BindingSupportImpl.Instance.isOwnException(x) истинно (что бы это ни значило). [b] Изменить: тайм-аут тайм-аута БД приложения:[/b]
Если настроен тайм-аут для App1 и/или App2, это может произойти (просто представьте, что App1.....CommandOrderPart.Set() занимает слишком много времени, в то время как App2 имеет настройку тайм-аута базы данных, это уже может вызвать проблему). Где я могу найти эти настройки таймаута? [b]Редактировать: предложение найти SQL-оператор, вызывающий такую ситуацию[/b]
По-видимому, проблема возникает при изменении статуса App1.....CommandOrderPart. Можно создать SQL-трассировку, отслеживающую все транзакции, выполняемые с этим объектом, следующим образом: [code]DECLARE @TraceID INT; DECLARE @MaxFileSize BIGINT = 50; -- File size limit in MB DECLARE @TraceFilePath NVARCHAR(256) = N'C:\SQLTraces\Trace_OrderPart'; -- Base trace file path
-- Step 3: Set a filter for the table CommandOrderParts EXEC sp_trace_setfilter @TraceID, 55, 0, 6, N'dbo.CommandOrderParts'; -- ObjectName filter
-- Optional: Add a filter for ApplicationName to capture specific applications EXEC sp_trace_setfilter @TraceID, 10, 0, 6, N'File_App1'; -- Filter for File_App1.dll EXEC sp_trace_setfilter @TraceID, 10, 1, 6, N'File_App2'; -- Filter for File_App2.dll
-- Step 4: Start the trace EXEC sp_trace_setstatus @TraceID, 1; -- Start the trace
-- Step 5: Stop the trace EXEC sp_trace_setstatus @TraceID, 0; -- Stop the trace [/code] Очевидно, я начинаю выполнение этого SQL-скрипта до шага 4. Если я хочу, чтобы сценарий остановился, я запускаю шаг 5. Ну, раньше Я забыл: сценарий, который я впервые нашел, содержал другие значения для событий. Я выполнил SQL-запрос SELECT @@VERSION и в результате получился Microsoft SQL Server 2017 (RTM-CU31-GDR) (KB5029376)..., я решил зайти на эту страницу, чтобы получить определения событий: [img]https://i.sstatic.net/Da7bsgT4.png[/img]
Я работаю над приложением, основанным на другом приложении, и оба основаны на Telerik OpenAccess для чтения базы данных SQL-Server.
Регулярно мой клиент сталкивается со следующим исключение:
Telerik.OpenAccess.OpenAccessException: Change operation...
Я работаю над приложением, основанным на другом приложении, и оба основаны на Telerik OpenAccess для чтения базы данных SQL-Server.
Регулярно мой клиент сталкивается со следующим исключение:
Telerik.OpenAccess.OpenAccessException: Change operation...
Я работаю над приложением, основанным на другом приложении, и оба основаны на Telerik OpenAccess для чтения базы данных SQL-Server.
Регулярно мой клиент сталкивается со следующим исключение:
Telerik.OpenAccess.OpenAccessException: Change operation...
Я работаю над приложением, основанным на другом приложении, и оба основаны на Telerik OpenAccess для чтения базы данных SQL-Server.
Регулярно мой клиент сталкивается со следующим исключение:
Telerik.OpenAccess.OpenAccessException: Change operation...
Я работаю над приложением, основанным на другом приложении, и оба основаны на Telerik OpenAccess для чтения базы данных SQL-Server.
Регулярно мой клиент сталкивается со следующим исключение:
Telerik.OpenAccess.OpenAccessException: Change operation...