Class RowLocking3
- All Implemented Interfaces:
LockingPolicy
- Direct Known Subclasses:
RowLockingRR
- See Also:
-
Field Summary
FieldsFields inherited from interface org.apache.derby.iapi.store.raw.LockingPolicy
MODE_CONTAINER, MODE_NONE, MODE_RECORD
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionint
getMode()
Get the mode of this policyprotected RowLock
Get type of lock to get while reading data.protected RowLock
Get type of lock to get while requesting "update" lock.protected RowLock
Get type of lock to get while writing data.boolean
lockContainer
(Transaction t, ContainerHandle container, boolean waitForLock, boolean forUpdate) Obtain container level intent lock.boolean
lockRecordForRead
(Transaction t, ContainerHandle container_handle, RecordHandle record, boolean waitForLock, boolean forUpdate) Obtain lock on record being read.boolean
lockRecordForWrite
(Transaction t, RecordHandle record, boolean lockForInsert, boolean waitForLock) Obtain lock on record being written.boolean
zeroDurationLockRecordForWrite
(Transaction t, RecordHandle record, boolean lockForInsertPreviousKey, boolean waitForLock) Obtain lock on record being written.Methods inherited from class org.apache.derby.impl.store.raw.xact.NoLocking
unlockContainer, unlockRecordAfterRead
-
Field Details
-
NO_LOCK
-
lf
-
-
Constructor Details
-
RowLocking3
-
-
Method Details
-
getReadLockType
Get type of lock to get while reading data.This routine is provided so that class's like RowLockingRR can override just this routine to get RS2 locks vs RS3 locks, and still reuse all the other code in this class.
- Returns:
- The lock type of a shared lock for this locking policy.
-
getUpdateLockType
Get type of lock to get while requesting "update" lock.This routine is provided so that class's like RowLockingRR can override just this routine to get RU2 locks vs RU3 locks, and still reuse all the other code in this class.
- Returns:
- The lock type of a shared lock for this locking policy.
-
getWriteLockType
Get type of lock to get while writing data.This routine is provided so that class's like RowLockingRR can override just this routine to get RX2 locks vs RX3 locks, and still reuse all the other code in this class.
- Returns:
- The lock type of a shared lock for this locking policy.
-
lockContainer
public boolean lockContainer(Transaction t, ContainerHandle container, boolean waitForLock, boolean forUpdate) throws StandardException Obtain container level intent lock.This implementation of row locking is 2 level, ie. table and row locking. It will interact correctly with tables opened with ContainerLocking3 locking mode.
Updater's will get table level IX locks, and X row locks.
Reader's will get table level IS locks, and S row locks.
- Specified by:
lockContainer
in interfaceLockingPolicy
- Overrides:
lockContainer
in classNoLocking
- Parameters:
t
- Transaction to associate lock with.container
- Container to lock.waitForLock
- Should lock request wait until granted?forUpdate
- Should container be locked for update, or read?- Returns:
- true if the lock was obtained, false if it wasn't. False should only be returned if the waitForLock policy was set to "false," and the lock was unavailable.
- Throws:
StandardException
- Standard exception policy.- See Also:
-
lockRecordForRead
public boolean lockRecordForRead(Transaction t, ContainerHandle container_handle, RecordHandle record, boolean waitForLock, boolean forUpdate) throws StandardException Obtain lock on record being read.Assumes that a table level IS has been acquired. Will acquire a Shared or Update lock on the row, depending on the "forUpdate" parameter.
- Specified by:
lockRecordForRead
in interfaceLockingPolicy
- Overrides:
lockRecordForRead
in classNoLocking
- Parameters:
t
- The transaction to associate the lock with.container_handle
- Open Container used to get record. Will be used to row locks by the container they belong to.record
- The record to be locked.waitForLock
- Should lock request wait until granted?forUpdate
- Whether to open for read or write access.- Returns:
- true if the lock was granted, false if waitForLock was false and the lock could not be granted.
- Throws:
StandardException
- Standard exception policy.- See Also:
-
zeroDurationLockRecordForWrite
public boolean zeroDurationLockRecordForWrite(Transaction t, RecordHandle record, boolean lockForInsertPreviousKey, boolean waitForLock) throws StandardException Obtain lock on record being written.Assumes that a table level IX has been acquired. Will acquire an Exclusive (X) lock on the row.
- Specified by:
zeroDurationLockRecordForWrite
in interfaceLockingPolicy
- Overrides:
zeroDurationLockRecordForWrite
in classNoLocking
- Parameters:
t
- transaction to associate the lock with.record
- The record to be locked.lockForInsertPreviousKey
- Lock is for a previous key of a insert.waitForLock
- Should lock request wait until granted?- Returns:
- true if the lock was granted, false if waitForLock was false and the lock could not be granted.
- Throws:
StandardException
- Standard exception policy.- See Also:
-
lockRecordForWrite
public boolean lockRecordForWrite(Transaction t, RecordHandle record, boolean lockForInsert, boolean waitForLock) throws StandardException Obtain lock on record being written.Assumes that a table level IX has been acquired. Will acquire an Exclusive (X) lock on the row.
- Specified by:
lockRecordForWrite
in interfaceLockingPolicy
- Overrides:
lockRecordForWrite
in classNoLocking
- Parameters:
t
- The transaction to associate the lock with.record
- The record to be locked.lockForInsert
- Lock is for an insert.waitForLock
- Should lock request wait until granted?- Returns:
- true if the lock was granted, false if waitForLock was false and the lock could not be granted.
- Throws:
StandardException
- Standard exception policy.- See Also:
-
getMode
public int getMode()Description copied from interface:LockingPolicy
Get the mode of this policy- Specified by:
getMode
in interfaceLockingPolicy
- Overrides:
getMode
in classNoLocking
-