/* * @(#)SerialDatalink.java 1.5 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.net.URL; /** * A serialized mapping in the Java programming language of an SQL * DATALINK value. A DATALINK value * references a file outside of the underlying data source that the * data source manages. *

* RowSet implementations can use the method RowSet.getURL * to retrieve a java.net.URL object, which can be used * to manipulate the external data. *

 *      java.net.URL url = rowset.getURL(1);
 * 
*/ public class SerialDatalink implements Serializable, Cloneable { /** * The extracted URL field retrieved from the DATALINK field. * @serial */ private URL url; /** * The SQL type of the elements in this SerialDatalink * object. The type is expressed as one of the contants from the * class java.sql.Types. * @serial */ private int baseType; /** * The type name used by the DBMS for the elements in the SQL * DATALINK value that this SerialDatalink object * represents. * @serial */ private String baseTypeName; /** * Constructs a new SerialDatalink object from the given * java.net.URL object. *

* @throws SerialException if url parameter is a null */ public SerialDatalink(URL url) throws SerialException { if (url == null) { throw new SerialException("Cannot serialize empty URL instance"); } this.url = url; } /** * Returns a new URL that is a copy of this SerialDatalink * object. * * @return a copy of this SerialDatalink object as a * URL object in the Java programming language. * @throws SerialException if the URL object cannot be de-serialized */ public URL getDatalink() throws SerialException { URL aURL = null; try { aURL = new URL((this.url).toString()); } catch (java.net.MalformedURLException e) { throw new SerialException("MalformedURLException: " + e.getMessage()); } return aURL; } /** * The identifier that assists in the serialization of this SerialDatalink * object. */ static final long serialVersionUID = 2826907821828733626L; }