[ 
https://issues.apache.org/jira/browse/DERBY-3683?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Knut Anders Hatlen updated DERBY-3683:
--------------------------------------

    Issue & fix info: [Workaround attached]
             Urgency: Normal

Triaged for 10.5.2.

> SYSCS_COMPRESS_TABLE gets deadlock while executing concurrently with other 
> user threads
> ---------------------------------------------------------------------------------------
>
>                 Key: DERBY-3683
>                 URL: https://issues.apache.org/jira/browse/DERBY-3683
>             Project: Derby
>          Issue Type: Bug
>          Components: SQL
>    Affects Versions: 10.4.1.3
>         Environment: Embedded Derby, Sun JDK 1.6.0_06-b02, Linux 
> 2.6.9-67.0.15.EL i686
>            Reporter: Juha Heljoranta
>            Priority: Minor
>
> Derby documentation about SYSCS_COMPRESS_TABLE says: "...procedure acquires 
> an exclusive table lock on the table being compressed." However, I get:
> java.sql.SQLException: The exception 'java.sql.SQLException: A lock could not 
> be obtained due to a deadlock, cycle of locks and waiters is:
> Lock : ROW, SYSCONGLOMERATES, (7,16)
>   Waiting XID : {13091, X} , APP, alter table "APP"."XYZ" compress sequential
>   Granted XID : {13091, S} , {13087, S} 
> Lock : TABLE, XYZ, Tablelock
>   Waiting XID : {13087, IX} , APP, update XYZ set FOO = ? where BAR = ? AND 
> ID = ?
>   Granted XID : {13091, X} 
> . The selected victim is XID : 13091.' was thrown while evaluating an 
> expression.
> if another thread is updating the same table while another thread executes:
> CallableStatement cs = conn.prepareCall("CALL 
> SYSCS_UTIL.SYSCS_COMPRESS_TABLE(?, ?, ?)");
> cs.setString(1, "APP");
> cs.setString(2, "XYZ");
> cs.setShort(3, (short) 1);
> cs.execute();
> conn.commit();
> Problem goes away if I acquire exclusive table lock manually right before the 
> compress table statement:
> conn.prepareStatement("LOCK TABLE XYZ IN EXCLUSIVE MODE").executeUpdate();

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.

Reply via email to