Обсуждение: Attempting to disable count triggers on cleanup

Поиск
Список
Период
Сортировка

Attempting to disable count triggers on cleanup

От
Dave Cramer
Дата:
I have a database that we want to keep track of counts of rows.

We have triggers on the rows which increment, and decrement a count
table. In order to speed up deleting many rows we have added the following

   if user != 'mocospace_cleanup'
then

        update user_profile_count set buddycount=buddycount-1 where
user_profile_count.uid=OLD.userid;
    end
if;


However in the logs we can see the following. I have checked to make
sure that the user really is the mocospace_cleanup user and checked
manually by logging in as the mocospace_cleanup user to make sure that
the code above does what it purports to.

ERROR:  deadlock detected
DETAIL:  Process 23063 waits for ExclusiveLock on tuple (20502,48) of
relation 48999028 of database 14510214; blocked by process 23110.
Process 23110 waits for ShareLock on transaction 1427023217; blocked by
process 23098.
...
CONTEXT:  SQL statement "update user_profile_count set
buddycount=buddycount-1 where user_profile_count.uid= $1 "
PL/pgSQL function "user_buddy_count" line 11 at SQL statement
SQL statement "DELETE FROM ONLY "public"."user_buddies" WHERE
"buddyuserid" = $1"

Dave

Re: Attempting to disable count triggers on cleanup

От
hubert depesz lubaczewski
Дата:
On Tue, Sep 25, 2007 at 07:08:42AM -0400, Dave Cramer wrote:
> ERROR:  deadlock detected
> DETAIL:  Process 23063 waits for ExclusiveLock on tuple (20502,48) of
> relation 48999028 of database 14510214; blocked by process 23110.
> Process 23110 waits for ShareLock on transaction 1427023217; blocked by
> process 23098.
> ...
> CONTEXT:  SQL statement "update user_profile_count set
> buddycount=buddycount-1 where user_profile_count.uid= $1 "
> PL/pgSQL function "user_buddy_count" line 11 at SQL statement
> SQL statement "DELETE FROM ONLY "public"."user_buddies" WHERE
> "buddyuserid" = $1"

take a look at:
http://www.depesz.com/index.php/2007/09/12/objects-in-categories-counters-with-triggers/

and if you want to temporarily disable trigger, simply do appropriate
"alter table disable trigger".

depesz

--
quicksil1er: "postgres is excellent, but like any DB it requires a
highly paid DBA.  here's my CV!" :)
http://www.depesz.com/ - blog dla ciebie (i moje CV)

Re: Attempting to disable count triggers on cleanup

От
Dave Cramer
Дата:
hubert depesz lubaczewski wrote:
> On Tue, Sep 25, 2007 at 07:08:42AM -0400, Dave Cramer wrote:
>
>> ERROR:  deadlock detected
>> DETAIL:  Process 23063 waits for ExclusiveLock on tuple (20502,48) of
>> relation 48999028 of database 14510214; blocked by process 23110.
>> Process 23110 waits for ShareLock on transaction 1427023217; blocked by
>> process 23098.
>> ...
>> CONTEXT:  SQL statement "update user_profile_count set
>> buddycount=buddycount-1 where user_profile_count.uid= $1 "
>> PL/pgSQL function "user_buddy_count" line 11 at SQL statement
>> SQL statement "DELETE FROM ONLY "public"."user_buddies" WHERE
>> "buddyuserid" = $1"
>>
>
> take a look at:
> http://www.depesz.com/index.php/2007/09/12/objects-in-categories-counters-with-triggers/
>
> and if you want to temporarily disable trigger, simply do appropriate
> "alter table disable trigger".
>
>
Well, that doesn't work inside a transaction I've tried it. This has
been fixed in 8.3

Dave
> depesz
>
>