|
HSQLDB example source code file (CachedRow.java)
The HSQLDB CachedRow.java source code
/*
* For work developed by the HSQL Development Group:
*
* Copyright (c) 2001-2010, The HSQL Development Group
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* Neither the name of the HSQL Development Group nor the names of its
* contributors may be used to endorse or promote products derived from this
* software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL HSQL DEVELOPMENT GROUP, HSQLDB.ORG,
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
*
*
* For work originally developed by the Hypersonic SQL Group:
*
* Copyright (c) 1995-2000, The Hypersonic SQL Group.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
*
* Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
*
* Neither the name of the Hypersonic SQL Group nor the names of its
* contributors may be used to endorse or promote products derived from this
* software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE HYPERSONIC SQL GROUP,
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* This software consists of voluntary contributions made by many individuals
* on behalf of the Hypersonic SQL Group.
*/
package org.hsqldb;
import java.io.IOException;
import org.hsqldb.lib.IntLookup;
import org.hsqldb.lib.java.JavaSystem;
import org.hsqldb.rowio.RowInputInterface;
import org.hsqldb.rowio.RowOutputInterface;
// fredt@users 20020221 - patch 513005 by sqlbob@users (RMP)
// fredt@users 20020920 - patch 1.7.1 - refactoring to cut memory footprint
// fredt@users 20021205 - patch 1.7.2 - enhancements
// fredt@users 20021215 - doc 1.7.2 - javadoc comments
// boucherb@users - 20040411 - doc 1.7.2 - javadoc comments
/**
* In-memory representation of a disk-based database row object with methods
* for serialization and de-serialization. <p>
*
* A CachedRow is normally part of a circular double linked list which
* contains all of the Rows currently in the Cache for the database. It is
* unlinked from this list when it is freed from the Cache to make way for
* other rows.
*
* New class from the Hypersonic Original
*
* @author Thomas Mueller (Hypersonic SQL Group)
* @version 1.7.2
* @since Hypersonic SQL
*/
public class CachedRow extends Row {
static final int NO_POS = -1;
//
protected Table tTable;
int storageSize;
/**
* Flag indicating unwritten data.
*/
protected boolean hasDataChanged;
/**
* Flag indicating Node data has changed.
*/
boolean hasNodesChanged;
/**
* Default constructor used only in subclasses.
*/
CachedRow() {}
public static CachedRow newCachedRow(Table t,
Object[] o) throws HsqlException {
if (t.isText) {
return new CachedDataRow(t, o);
} else {
return new CachedRow(t, o);
}
}
/**
* Constructor for new Rows. Variable hasDataChanged is set to true in
* order to indicate the data needs saving.
*
* @param t table
* @param o row data
* @throws HsqlException if a database access error occurs
*/
CachedRow(Table t, Object[] o) throws HsqlException {
tTable = t;
int indexcount = t.getIndexCount();
nPrimaryNode = Node.newNode(this, 0, t);
Node n = nPrimaryNode;
for (int i = 1; i < indexcount; i++) {
n.nNext = Node.newNode(this, i, t);
n = n.nNext;
}
oData = o;
hasDataChanged = hasNodesChanged = true;
}
/**
* Constructor when read from the disk into the Cache.
*
* @param t table
* @param in data source
* @throws IOException
* @throws HsqlException
*/
public CachedRow(Table t,
RowInputInterface in) throws IOException, HsqlException {
tTable = t;
iPos = in.getPos();
storageSize = in.getSize();
int indexcount = t.getIndexCount();
nPrimaryNode = Node.newNode(this, in, 0, t);
Node n = nPrimaryNode;
for (int i = 1; i < indexcount; i++) {
n.nNext = Node.newNode(this, in, i, t);
n = n.nNext;
}
oData = in.readData(tTable.getColumnTypes());
}
private void readRowInfo(RowInputInterface in)
throws IOException, HsqlException {
// for use when additional transaction info is attached to rows
}
/**
* This method is called only when the Row is deleted from the database
* table. The links with all the other objects apart from the data
* are removed.
*
* @throws HsqlException
*/
public void delete() throws HsqlException {
super.delete();
hasNodesChanged = hasDataChanged = false;
tTable = null;
}
public int getStorageSize() {
return storageSize;
}
/**
* Sets the file position for the row
*
* @param pos position in data file
*/
public void setPos(int pos) {
iPos = pos;
}
/**
* Sets flag for Node data change.
*/
void setChanged() {
hasNodesChanged = true;
}
/**
* Returns true if Node data has changed.
*
* @return boolean
*/
public boolean hasChanged() {
return hasNodesChanged;
}
/**
* Returns the Table to which this Row belongs.
*
* @return Table
*/
public Table getTable() {
return tTable;
}
/**
* returned size does not include the row size written at the beginning
*/
public int getRealSize(RowOutputInterface out) {
return tTable.getIndexCount() * DiskNode.SIZE_IN_BYTE
+ out.getSize(this);
}
public void setStorageSize(int size) {
storageSize = size;
}
/**
* Returns true if any of the Nodes for this row is a root node.
* Used only in Cache.java to avoid removing the row from the cache.
*
* @return boolean
* @throws HsqlException
*/
synchronized public boolean isKeepInMemory() {
Node n = nPrimaryNode;
while (n != null) {
if (n.isRoot()) {
return true;
}
n = n.nNext;
}
return false;
}
/**
* Using the internal reference to the Table, returns the current cached
* Row. Valid for deleted rows only before any subsequent insert or
* update on any cached table.<p>
*
* Access to tables while performing the internal operations for an
* SQL statement result in CachedRow objects to be cleared from the cache.
* This method returns the CachedRow, loading it to the cache if it is not
* there.
* @return the current Row in Cache for this Object
* @throws HsqlException
*/
synchronized Row getUpdatedRow() throws HsqlException {
return tTable == null ? null
: (CachedRow) tTable.rowStore.get(iPos);
}
/**
* used in CachedDataRow
*/
void setNewNodes() {}
/**
* Used exclusively by Cache to save the row to disk. New implementation
* in 1.7.2 writes out only the Node data if the table row data has not
* changed. This situation accounts for the majority of invocations as
* for each row deleted or inserted, the Nodes for several other rows
* will change.
*
* @param output data source
* @throws IOException
* @throws HsqlException
*/
public void write(RowOutputInterface out) {
try {
writeNodes(out);
if (hasDataChanged) {
out.writeData(oData, tTable);
out.writeEnd();
hasDataChanged = false;
}
} catch (IOException e) {}
}
private void writeRowInfo(RowOutputInterface out) {
// for use when additional transaction info is attached to rows
}
public void write(RowOutputInterface out, IntLookup lookup) {
out.writeSize(storageSize);
Node rownode = nPrimaryNode;
while (rownode != null) {
((DiskNode) rownode).writeTranslate(out, lookup);
rownode = rownode.nNext;
}
out.writeData(getData(), getTable());
out.writeEnd();
}
/**
* Writes the Nodes, immediately after the row size.
*
* @param out
*
* @throws IOException
* @throws HsqlException
*/
private void writeNodes(RowOutputInterface out) throws IOException {
out.writeSize(storageSize);
Node n = nPrimaryNode;
while (n != null) {
n.write(out);
n = n.nNext;
}
hasNodesChanged = false;
}
/**
* With CACHED tables there may possibly exist two copies of the row.
* All copies will have the same iPos.
*
* @param obj row to compare
* @return boolean
*/
public boolean equals(Object obj) {
if (obj == this) {
return true;
}
if (obj instanceof CachedRow) {
return ((CachedRow) obj).iPos == iPos;
}
return false;
}
/**
* Hash code is valid only until a modification to the cache
*
* @return file position of row
*/
public int hashCode() {
return iPos;
}
}
Other HSQLDB examples (source code examples)Here is a short list of links related to this HSQLDB CachedRow.java source code file: |
| ... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.