I have a stored procedure (called from Appian’s Execute Stored Procedure smart service) that reads from a view and then creates, updates, or deletes rows in a materialized table that is also sourced from that same view.
The view is heavily used by multiple applications, so I created the stored procedure smart service to read the updated values from the view and reflect them in the materialized table. This process is triggered by various create or update forms across different applications.
Most of the time the stored procedure works, but sometimes it fails with the following error:
Deadlock found when trying to get lock; try restarting transaction
How can I reduce or avoid these deadlocks?
Discussion posts and replies are publicly visible
I do not understand why you directly modify data in that materialized view. Isn't the idea that it updates itself?
Is it not possible to use the Data Fabric for your purposes? The Data Fabric is, effectively, a materialized layer on top of your database. It has a small learning curve, and older applications need to be refactored into it, but it serves its purpose extremely well.