All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.as400.access.AS400JDBCSQLXMLLocator Maven / Gradle / Ivy

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                                 
//                                                                             
// Filename: AS400JDBCSQLXMLLocator.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 2006-2009 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

/* ifdef JDBC40 */
import java.io.InputStream;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.io.Writer;
/* endif */ 
import java.sql.SQLException;
/* ifdef JDBC40 */
import java.sql.SQLXML;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamReader;
import javax.xml.transform.Result;
import javax.xml.transform.Source;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.sax.SAXSource;
import javax.xml.transform.stax.StAXSource;

import javax.xml.transform.stream.StreamSource;

import org.w3c.dom.Document;
import org.xml.sax.InputSource;
/* endif */ 

//import com.sun.xml.internal.fastinfoset.stax.StAXDocumentParser;


//@PDA jdbc40 new class
//@xml2 whole class is redesigned after that of The Native Driver
/**

The AS400JDBCSQLXMLLocator class provides the object interface for using XML data through JDBC. The mapping in the Java programming language for the SQL XML type. XML is a built-in type that stores an XML value as a column value in a row of a database table. The SQLXML interface provides methods for accessing the XML value as a String, a Reader or Writer, or as a Stream. **/ public class AS400JDBCSQLXMLLocator extends AS400JDBCSQLXML { /** Constructs an AS400JDBCSQLXMLLocator object of Clob/DBClob locator data. (This constructor signature is only available on ClobLocator.) This could be created as a result of an actual XML column or some other data type column and calling resultSet.getSQLXML() The data for the SQLXML will be retrieved as requested, directly from the IBM i system, using the locator handle. @param locator The locator. @param converter The text converter. @param savedObject Saved Object. @param savedScale Saved scale. @param isXML Flag that stream is from an XML column type (needed to strip xml declaration) **/ AS400JDBCSQLXMLLocator(JDLobLocator locator, ConvTable converter, Object savedObject, int savedScale, boolean isXml) { super(); //Since SQLXML has both text and binary getter methods, we need to preserve converter, but need to be able to get //to the bits as binary without doing any conversion or trimming of XML declaration //Native JDBC changed to always trim off xml header if accessing data through SQLXML object even it column is not XML...(TB also will now do this) isXml = true;//@xmltrim (match native jdbc for trimming xml decl if using sqlxml) clobLocatorValue_ = new AS400JDBCClobLocator( locator, converter, savedObject, savedScale, isXml); //@xml4 allow AS400JDBCClobLocator to trim off xml header if needed if(isXml) blobLocatorValue_ = new AS400JDBCBlobLocator( locator, savedObject, savedScale); //@xml6 also need ref to bloblocator in case SQLXML.getBinaryStream is called lobType = SQLData.CLOB_LOCATOR; isXML_ = isXml; //@xml4 } /** Constructs an AS400JDBCSQLXMLLocator object of BlobLocator data. (This constructor signature is only available on BlobLocator.) The data for the BLOB will be retrieved as requested, directly from the IBM i system, using the locator handle. @param locator The locator. @param savedObject Saved Object. @param savedScale Saved scale. **/ AS400JDBCSQLXMLLocator(JDLobLocator locator, Object savedObject, int savedScale) { super(); blobLocatorValue_ = new AS400JDBCBlobLocator( locator, savedObject, savedScale); lobType = SQLData.BLOB_LOCATOR; isXML_ = true;//@xmltrim (match native jdbc for trimming xml decl if using sqlxml) } //@olddesc /** Returns the handle to this locator in the database. @return The handle to this locator in the databaes. **/ synchronized int getHandle()throws SQLException { if(clobLocatorValue_ != null) return clobLocatorValue_.getHandle(); else if(blobLocatorValue_ != null) return blobLocatorValue_.getHandle(); else return -1; //not set or updated by non-locator value and not needed } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy