Java Doc for B2IRowLocking3.java in  » Database-DBMS » db-derby-10.2 » org » apache » derby » impl » store » access » btree » index » Java Source Code / Java DocumentationJava Source Code and Java Documentation

Java Source Code / Java Documentation
1. 6.0 JDK Core
2. 6.0 JDK Modules
3. 6.0 JDK Modules com.sun
4. 6.0 JDK Modules com.sun.java
5. 6.0 JDK Modules sun
6. 6.0 JDK Platform
7. Ajax
8. Apache Harmony Java SE
9. Aspect oriented
10. Authentication Authorization
11. Blogger System
12. Build
13. Byte Code
14. Cache
15. Chart
16. Chat
17. Code Analyzer
18. Collaboration
19. Content Management System
20. Database Client
21. Database DBMS
22. Database JDBC Connection Pool
23. Database ORM
24. Development
25. EJB Server geronimo
26. EJB Server GlassFish
27. EJB Server JBoss 4.2.1
28. EJB Server resin 3.1.5
29. ERP CRM Financial
30. ESB
31. Forum
32. GIS
33. Graphic Library
34. Groupware
35. HTML Parser
36. IDE
37. IDE Eclipse
38. IDE Netbeans
39. Installer
40. Internationalization Localization
41. Inversion of Control
42. Issue Tracking
43. J2EE
44. JBoss
45. JMS
46. JMX
47. Library
48. Mail Clients
49. Net
50. Parser
51. PDF
52. Portal
53. Profiler
54. Project Management
55. Report
56. RSS RDF
57. Rule Engine
58. Science
59. Scripting
60. Search Engine
61. Security
62. Sevlet Container
63. Source Control
64. Swing Library
65. Template Engine
66. Test Coverage
67. Testing
68. UML
69. Web Crawler
70. Web Framework
71. Web Mail
72. Web Server
73. Web Services
74. Web Services apache cxf 2.0.1
75. Web Services AXIS2
76. Wiki Engine
77. Workflow Engines
78. XML
79. XML UI
Java
Java Tutorial
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
Photoshop Tutorials
Maya Tutorials
Flash Tutorials
3ds-Max Tutorials
Illustrator Tutorials
GIMP Tutorials
C# / C Sharp
C# / CSharp Tutorial
C# / CSharp Open Source
ASP.Net
ASP.NET Tutorial
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++
C++ Tutorial
Ruby
PHP
Python
Python Tutorial
Python Open Source
SQL Server / T-SQL
SQL Server / T-SQL Tutorial
Oracle PL / SQL
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
XML
XML Tutorial
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
Java Source Code / Java Documentation » Database DBMS » db derby 10.2 » org.apache.derby.impl.store.access.btree.index 
Source Cross Reference  Class Diagram Java Document (Java Doc) 


java.lang.Object
   org.apache.derby.impl.store.access.btree.index.B2IRowLocking3

All known Subclasses:   org.apache.derby.impl.store.access.btree.index.B2IRowLockingRR,
B2IRowLocking3
class B2IRowLocking3 implements BTreeLockingPolicy(Code)
Implements the jdbc serializable isolation level using row locks.

Holds read and write locks until end of transaction. Obtains previous key locks to protect from phantom reads.



Field Summary
protected  ConglomerateControllerbase_cc
     The container id of the base container for this index.
protected  OpenBTreeopen_btree
     The OpenBtree to use if we have to lock anything in the btree vs.

Constructor Summary
 B2IRowLocking3(Transaction rawtran, int lock_level, LockingPolicy locking_policy, ConglomerateController base_cc, OpenBTree open_btree)
    

Method Summary
protected  boolean_lockScanRow(OpenBTree open_btree, BTree btree, BTreeRowPosition pos, boolean request_row_lock, boolean request_scan_lock, FetchDescriptor lock_fetch_desc, DataValueDescriptor[] lock_template, RowLocation lock_row_loc, boolean previous_key_lock, boolean forUpdate, int lock_operation)
     Lock a row as part of doing the scan.

Lock the row at the given slot (or the previous row if slot is 0). Get the scan lock on the page if "request_scan_lock" is true.

If this routine returns true all locks were acquired while maintaining the latch on leaf.

public  booleanlockNonScanPreviousRow(BTree btree, LeafControlRow current_leaf, int current_slot, FetchDescriptor lock_fetch_desc, DataValueDescriptor[] lock_template, RowLocation lock_row_loc, OpenBTree open_btree, int lock_operation, int lock_duration)
     Lock the row previous to the input row.
public  booleanlockNonScanRow(BTree btree, LeafControlRow current_leaf, LeafControlRow aux_leaf, DataValueDescriptor[] current_row, int lock_operation)
     Lock the in memory row.
public  booleanlockNonScanRowOnPage(BTree btree, LeafControlRow current_leaf, int current_slot, FetchDescriptor lock_fetch_desc, DataValueDescriptor[] lock_template, RowLocation lock_row_loc, int lock_operation)
    
public  booleanlockScan(LeafControlRow current_leaf, ControlRow aux_control_row, boolean forUpdate, int lock_operation)
     Lock a control row page for scan.
public  booleanlockScanCommittedDeletedRow(OpenBTree open_btree, LeafControlRow leaf, DataValueDescriptor[] template, FetchDescriptor lock_fetch_desc, int slot_no)
     Lock a btree row to determine if it is a committed deleted row.
public  booleanlockScanForReclaimSpace(LeafControlRow current_leaf)
     Lock a control row page for reclaiming deleted rows.

When reclaiming deleted rows during split need to get an exclusive scan lock on the page, which will mean there are no other scans positioned on the page.

public  booleanlockScanRow(OpenBTree open_btree, BTree btree, BTreeRowPosition pos, boolean request_scan_lock, FetchDescriptor lock_fetch_desc, DataValueDescriptor[] lock_template, RowLocation lock_row_loc, boolean previous_key_lock, boolean forUpdate, int lock_operation)
     Lock a row as part of doing the scan.

Lock the row at the given slot (or the previous row if slot is 0). Get the scan lock on the page if "request_scan_lock" is true.

If this routine returns true all locks were acquired while maintaining the latch on leaf.

public  voidunlockScan(long page_number)
     Release the lock gotten by calling lockScan.
public  voidunlockScanRecordAfterRead(BTreeRowPosition pos, boolean forUpdate)
     Release read lock on a row.

Field Detail
base_cc
protected ConglomerateController base_cc(Code)
The container id of the base container for this index. Used to build record handles to make lock calls on.



open_btree
protected OpenBTree open_btree(Code)
The OpenBtree to use if we have to lock anything in the btree vs. base row locking.




Constructor Detail
B2IRowLocking3
B2IRowLocking3(Transaction rawtran, int lock_level, LockingPolicy locking_policy, ConglomerateController base_cc, OpenBTree open_btree)(Code)
Constructors for This class:




Method Detail
_lockScanRow
protected boolean _lockScanRow(OpenBTree open_btree, BTree btree, BTreeRowPosition pos, boolean request_row_lock, boolean request_scan_lock, FetchDescriptor lock_fetch_desc, DataValueDescriptor[] lock_template, RowLocation lock_row_loc, boolean previous_key_lock, boolean forUpdate, int lock_operation) throws StandardException(Code)
Lock a row as part of doing the scan.

Lock the row at the given slot (or the previous row if slot is 0). Get the scan lock on the page if "request_scan_lock" is true.

If this routine returns true all locks were acquired while maintaining the latch on leaf. If this routine returns false, locks may or may not have been acquired, and the routine should be called again after the client has researched the tree to reget the latch on the appropriate page. (p> As a sided effect stores the value of the record handle of the current scan lock. Whether locks were acquired without releasing latch on leaf.
Parameters:
  open_btree - The open_btree to associate latches with - used if routine has to scan backward.
Parameters:
  btree - the conglomerate info.
Parameters:
  pos - The position of the row to lock.
Parameters:
  request_row_lock - Whether to request the row lock, shouldonly be requested once per page in the scan.
Parameters:
  request_scan_lock - Whether to request the page scan lock, shouldonly be requested once per page in the scan.
Parameters:
  lock_fetch_desc - The fetch descriptor to use to fetch therow location for the lock request.
Parameters:
  lock_template - A scratch area to use to read in rows.
Parameters:
  previous_key_lock - Is this a previous key lock call?
Parameters:
  forUpdate - Is the scan for update or for read only.
exception:
  StandardException - Standard exception policy.




lockNonScanPreviousRow
public boolean lockNonScanPreviousRow(BTree btree, LeafControlRow current_leaf, int current_slot, FetchDescriptor lock_fetch_desc, DataValueDescriptor[] lock_template, RowLocation lock_row_loc, OpenBTree open_btree, int lock_operation, int lock_duration) throws StandardException(Code)
Lock the row previous to the input row.

See BTree.lockPreviousRow() for more info.
exception:
  StandardException - Standard exception policy.




lockNonScanRow
public boolean lockNonScanRow(BTree btree, LeafControlRow current_leaf, LeafControlRow aux_leaf, DataValueDescriptor[] current_row, int lock_operation) throws StandardException(Code)
Lock the in memory row.

See BTree.lockRow() for more info.
exception:
  StandardException - Standard exception policy.




lockNonScanRowOnPage
public boolean lockNonScanRowOnPage(BTree btree, LeafControlRow current_leaf, int current_slot, FetchDescriptor lock_fetch_desc, DataValueDescriptor[] lock_template, RowLocation lock_row_loc, int lock_operation) throws StandardException(Code)



lockScan
public boolean lockScan(LeafControlRow current_leaf, ControlRow aux_control_row, boolean forUpdate, int lock_operation) throws StandardException(Code)
Lock a control row page for scan.

Scanners get shared lock on the page while positioned on a row within the page, splitter/purgers/mergers get exclusive lock on the page. See BTree.lockScan() for more info.
exception:
  StandardException - Standard exception policy.




lockScanCommittedDeletedRow
public boolean lockScanCommittedDeletedRow(OpenBTree open_btree, LeafControlRow leaf, DataValueDescriptor[] template, FetchDescriptor lock_fetch_desc, int slot_no) throws StandardException(Code)
Lock a btree row to determine if it is a committed deleted row.


See Also:   BTreeLockingPolicy.lockScanCommittedDeletedRow
exception:
  StandardException - Standard exception policy.




lockScanForReclaimSpace
public boolean lockScanForReclaimSpace(LeafControlRow current_leaf) throws StandardException(Code)
Lock a control row page for reclaiming deleted rows.

When reclaiming deleted rows during split need to get an exclusive scan lock on the page, which will mean there are no other scans positioned on the page. If there are other scans positioned, just give up on reclaiming space now. true if lock was granted nowait, else false and not lock wasgranted.
exception:
  StandardException - Standard exception policy.




lockScanRow
public boolean lockScanRow(OpenBTree open_btree, BTree btree, BTreeRowPosition pos, boolean request_scan_lock, FetchDescriptor lock_fetch_desc, DataValueDescriptor[] lock_template, RowLocation lock_row_loc, boolean previous_key_lock, boolean forUpdate, int lock_operation) throws StandardException(Code)
Lock a row as part of doing the scan.

Lock the row at the given slot (or the previous row if slot is 0). Get the scan lock on the page if "request_scan_lock" is true.

If this routine returns true all locks were acquired while maintaining the latch on leaf. If this routine returns false, locks may or may not have been acquired, and the routine should be called again after the client has researched the tree to reget the latch on the appropriate page. (p> As a sided effect stores the value of the record handle of the current scan lock. Whether locks were acquired without releasing latch on leaf.
Parameters:
  open_btree - The open_btree to associate latches with - used if routine has to scan backward.
Parameters:
  btree - the conglomerate info.
Parameters:
  pos - The position of the row to lock.
Parameters:
  request_scan_lock - Whether to request the page scan lock, shouldonly be requested once per page in the scan.
Parameters:
  lock_template - A scratch area to use to read in rows.
Parameters:
  previous_key_lock - Is this a previous key lock call?
Parameters:
  forUpdate - Is the scan for update or for read only.
exception:
  StandardException - Standard exception policy.




unlockScan
public void unlockScan(long page_number)(Code)
Release the lock gotten by calling lockScan. This call can only be made to release read scan locks, write scan locks must be held until end of transaction.

See BTree.unlockScan() for more info.




unlockScanRecordAfterRead
public void unlockScanRecordAfterRead(BTreeRowPosition pos, boolean forUpdate) throws StandardException(Code)
Release read lock on a row. For serializable, there is no work to do.



Methods inherited from java.lang.Object
native protected Object clone() throws CloneNotSupportedException(Code)(Java Doc)
public boolean equals(Object obj)(Code)(Java Doc)
protected void finalize() throws Throwable(Code)(Java Doc)
final native public Class getClass()(Code)(Java Doc)
native public int hashCode()(Code)(Java Doc)
final native public void notify()(Code)(Java Doc)
final native public void notifyAll()(Code)(Java Doc)
public String toString()(Code)(Java Doc)
final native public void wait(long timeout) throws InterruptedException(Code)(Java Doc)
final public void wait(long timeout, int nanos) throws InterruptedException(Code)(Java Doc)
final public void wait() throws InterruptedException(Code)(Java Doc)

w__w__w_.__ja___v___a_2__s___.c_o__m | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.