Solution: The inserts of the foreign key to tb_entity were blocking the updates to those rows of tb_entity. I solved the problem by making the foreign key constraints deferrable and deferring checking on them till the end of the transaction.
On Tue, May 21, 2013 at 3:24 PM, Moshe Jacobson <mo...@neadwerx.com> wrote: > On Tue, May 21, 2013 at 2:39 PM, Moshe Jacobson <mo...@neadwerx.com>wrote: > >> What could be causing this ROW SHARE lock to be in place for some cloning >> operations and not others? Perhaps there is a way to see which specific >> statement is causing the lock to occur, but I'm not sure how to look this >> up. Any help would be appreciated. >> > > Update: > > Apparently the hanging updates to tb_entity are not only related to > fn_clone_location_map(), because a hung update to tb_entity did not > correspond to a running instance of fn_clone_location_map(). > > I looked at pg_locks for one hung update to tb_entity, and it said it had > an un-granted lock of type transactionid, for another transaction ID. > > I wanted to see what was happening in that transaction ID that might be > causing this lock to be held, but I was unsure how. I know I can look in > pg_locks for the other transaction, but that will not tell me what > statement is executing in that transaction. pg_stat_activity does not have > a transaction ID column. > > How can I see what statement is executing in a transaction? > > > -- > Moshe Jacobson > Nead Werx, Inc. | Manager of Systems Engineering > 2323 Cumberland Parkway, Suite 201 | Atlanta, GA 30339 > mo...@neadwerx.com | www.neadwerx.com > > "Quality is not an act, it is a habit." -- Aristotle > -- Moshe Jacobson Nead Werx, Inc. | Manager of Systems Engineering 2323 Cumberland Parkway, Suite 201 | Atlanta, GA 30339 mo...@neadwerx.com | www.neadwerx.com "Quality is not an act, it is a habit." -- Aristotle