/* * @(#)SerialRef.java 1.7 04/05/29 * * Copyright 2004 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. */ package javax.sql.rowset.serial; import java.sql.*; import java.io.*; import java.util.*; /** * A serialized mapping of a Ref object, which is the mapping in the * Java programming language of an SQL REF value. *

* The SerialRef class provides a constructor for * creating a SerialRef instance from a Ref * object and provides methods for getting and setting the Ref object. */ public class SerialRef implements Ref, Serializable, Cloneable { /** * String containing the base type name. * @serial */ private String baseTypeName; /** * This will store the type Ref as an Object. */ private Object object; /** * Private copy of the Ref reference. */ private Ref reference; /** * Constructs a SerialRef object from the given Ref * object. * * @param ref a Ref object; cannot be null * @throws SQLException if a database access occurs; if ref * is null; or if the Ref object returns a * null value base type name. * @throws SerialException if an error occurs serializing the Ref * object */ public SerialRef(Ref ref) throws SerialException, SQLException { if (ref == null) { throw new SQLException("Cannot instantiate a SerialRef object " + "with a null Ref object"); } reference = ref; object = ref; if (ref.getBaseTypeName() == null) { throw new SQLException("Cannot instantiate a SerialRef object " + "that returns a null base type name"); } else { baseTypeName = new String(ref.getBaseTypeName()); } } /** * Returns a string describing the base type name of the Ref. * * @return a string of the base type name of the Ref * @throws SerialException in no Ref object has been set */ public String getBaseTypeName() throws SerialException { return baseTypeName; } /** * Returns an Object representing the SQL structured type * to which this SerialRef object refers. The attributes * of the structured type are mapped according to the given type map. * * @param map a java.util.Map object containing zero or * more entries, with each entry consisting of 1) a String * giving the fully qualified name of a UDT and 2) the * Class object for the SQLData implementation * that defines how the UDT is to be mapped * @return an object instance resolved from the Ref reference and mapped * according to the supplied type map * @throws SerialException if an error is encountered in the reference * resolution */ public Object getObject(java.util.Map> map) throws SerialException { map = new Hashtable(map); if (!object.equals(null)) { return map.get(object); } else { throw new SerialException("The object is not set"); } } /** * Returns an Object representing the SQL structured type * to which this SerialRef object refers. * * @return an object instance resolved from the Ref reference * @throws SerialException if an error is encountered in the reference * resolution */ public Object getObject() throws SerialException { if (reference != null) { try { return reference.getObject(); } catch (SQLException e) { throw new SerialException("SQLException: " + e.getMessage()); } } if (object != null) { return object; } throw new SerialException("The object is not set"); } /** * Sets the SQL structured type that this SerialRef object * references to the given Object object. * * @param obj an Object representing the SQL structured type * to be referenced * @throws SerialException if an error is encountered generating the * the structured type referenced by this SerialRef object */ public void setObject(Object obj) throws SerialException { try { reference.setObject(obj); } catch (SQLException e) { throw new SerialException("SQLException: " + e.getMessage()); } object = obj; } /** * The identifier that assists in the serialization of this SerialRef * object. */ static final long serialVersionUID = -4727123500609662274L; }