⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cursor.java

📁 一个OR Mapping工具
💻 JAVA
字号:
//-< Cursor.java >---------------------------------------------------*--------*
// JORA                       Version 2.0        (c) 1998  GARRET    *     ?  *
// (Java Object Relational Adapter)                                  *   /\|  *
//                                                                   *  /  \  *
//                          Created:     10-Jun-98    K.A. Knizhnik  * / [] \ *
//                          Last update: 20-Jun-98    K.A. Knizhnik  * GARRET *
//-------------------------------------------------------------------*--------*
// Cursor for navigation thru result of SELECT statement 
//-------------------------------------------------------------------*--------*

package jora;

import java.util.*;
import java.lang.reflect.*;
import java.sql.*;

/** Cursor is used for successive access to records fetched by SELECT 
 *  statement. As far as records can be retrived from several derived tables 
 *  (polymorphic form of select), this class can issue several requests
 *  to database. Cursor also provides methods for updating/deleting current 
 *  record.
 */
public class Cursor {
    /**
     * A cursor is initially positioned before its first row; the
     * first call to next makes the first row the current row; the
     * second call makes the second row the current row, etc. 
     *
     * <P>If an input stream from the previous row is open, it is
     * implicitly closed. The ResultSet's warning chain is cleared
     * when a new row is read.
     *
     * @return object constructed from fetched record or null if there
     * are no more rows 
     */
     public Object next() {  
        try { 
            do { 
	        if (result == null) {
		    if (table.isAbstract) {
		        table = table.derived;
			continue;
		    }
		    if (qbeObject != null) { 
	 	        String sql = "select " + table.listOfFields 
			    + " from " + table.name + " " + query;
			PreparedStatement qbeStmt;
			synchronized(session.preparedStmtHash) { 
			    Object s = session.preparedStmtHash.get(sql); 
			    if (s == null) { 
				qbeStmt=session.connection.prepareStatement(sql);
				session.preparedStmtHash.put(sql, qbeStmt);
			    } else { 
				qbeStmt = (PreparedStatement)s;
			    }
			}
			synchronized(qbeStmt) { 
			    table.bindQueryVariables(qbeStmt, qbeObject);
			    result = qbeStmt.executeQuery();
			    qbeStmt.clearParameters();
			}
		    } else { 
  		        if (stmt == null) { 
			    stmt = session.connection.createStatement();
			}
	 	        String sql = "select " + table.listOfFields 
			           + " from " + table.name + " " + query;
			result = stmt.executeQuery(sql);
		    } 
		}
		if (result.next()) { 
		    return currObject = table.load(result);
		} 
		result.close();
		result = null;
		currObject = null;
		table = table.derived;
	    } while (--nTables != 0);

	    if (stmt != null) { 
	        stmt.close();
	    }
	}
	catch (SQLException ex) { session.handleSQLException(ex); }
	return null;
    }

    /** Update current record pointed by cursor. This method can be called 
     *  only after next() method, which returns non-null object. This objects
     *  is used to update current record fields.<P>
     *
     *  If you are going to update or delete selected records, you should add
     *  "for update" clause to select statement. So parameter of
     *  <CODE>jora.Table.select()</CODE> statement should contain "for update"
     *  clause: 
     *  <CODE>record.table.Select("where name='xyz' for update");</CODE><P>
     * 
     *  <I><B>Attention!</I></B> 
     *  Not all database drivers support update operation with 
     *  cursor. This method will not work with such database drivers.
     */
    public void update() {
        if (currObject == null) { 
	    throw new NoCurrentObjectError();
	}
	try { 
	    table.updateVariables(result, currObject);
	} 
        catch (SQLException ex) { session.handleSQLException(ex); }
    }

    /** Delete current record pointed by cursor. This method can be called 
     *  only after next() method, which returns non-null object.<P>
     *
     *  If you are going to update or delete selected records, you should add
     *  "for update" clause to select statement. So parameter of
     *  <CODE>jora.Table.select()</CODE> statement should contain "for update"
     *  clause: 
     *  <CODE>record.table.Select("where name='xyz' for update");</CODE><P>
     * 
     *  <I><B>Attention!</I></B> 
     *  Not all database drivers support delete operation with cursor. 
     *  This method will not work with such database drivers.
     */
    public void delete() {
        if (currObject == null) { 
	    throw new NoCurrentObjectError();
	}
	try { 
	    result.deleteRow();
	} 
        catch (SQLException ex) { session.handleSQLException(ex); }
    }

    /** Extracts no more than <I>maxElements</I> records from database and
     *  store them into array. It is possible to extract rest records
     *  by successive next() or toArray() calls. Selected objects should
     *  have now components of InputStream, Blob or Clob type, because 
     *  their data will be not available after fetching next record.
     * 
     * @param maxElements limitation for result array size (and also for number
     *  of fetched records)
     * @return Array with objects constructed from fetched records.
     */
    public Object[] toArray(int maxElements) {
	Vector v = new Vector(maxElements < 100 ? maxElements : 100);
	Object o;
	while (--maxElements >= 0 && (o = next()) != null) { 
	    v.addElement(o);
	}
	Object[] a = new Object[v.size()];
	v.copyInto(a);
	return a;
    }

    /** Store all objects returned by SELECT query into array of Object.
     *  Selected objects should have now components of InputStream, Blob or 
     *  Clob type, because their data will be not available after fetching 
     *  next record.
     * 
     * @return Array with objects constructed from fetched records.
     */
    public Object[] toArray() { return toArray(Integer.MAX_VALUE); }

    /** Extracts no more than <I>maxElements</I> records from database and
     *  store them into array. It is possible to extract rest records
     *  by successive next() or toArray() calls. Selected objects should
     *  have now components of InputStream, Blob or Clob type, because
     *  their data will be not available after fetching next record.
     *
     * @param maxElements limitation for result array size (and also for number
     *  of fetched records)
     * @return List with objects constructed from fetched records.
     */
    public List toArrayList(int maxElements) {
         ArrayList al = new ArrayList(maxElements < 100 ? maxElements : 100);
         Object o;
         while (--maxElements >= 0 && (o = next()) != null) {
            al.add(o);
         }
         return al;
    }

    /** Store all objects returned by SELECT query into a list of Object.
     *  Selected objects should have now components of InputStream, Blob or
     *  Clob type, because their data will be not available after fetching
     *  next record.
     *
     * @return Array with objects constructed from fetched records.
     */
    public List toArrayList() { return toArrayList(Integer.MAX_VALUE); }

    // Internals 

    protected Cursor(Table table, Session session, int nTables, String query) { 
	if (session == null) { 
	    session = ((SessionThread)Thread.currentThread()).session;
	}	    
        this.table = table;
	this.session = session;
        this.nTables = nTables;
        this.query = query;
    }

    protected Cursor(Table table, Session session, int nTables, Object obj) { 
	if (session == null) { 
	    session = ((SessionThread)Thread.currentThread()).session;
	}	    
        this.table = table;
	this.session = session;
	this.nTables = nTables;
	qbeObject = obj; 
	query = table.buildQueryList(obj);
	stmt = null;
    }
  
    private Table     table; 
    private Session   session;
    private int       nTables;
    private ResultSet result;
    private String    query;
    private Statement stmt;
    private Object    currObject;
    private Object    qbeObject;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -