6 WebLogic Server でのサードパーティ ドライバの使い方
SQL 例外ブロックを開始する
この try/catch ブロックでは、Blob ロケータを取得して、Oracle Blob 拡張機能に アクセスします。
try {
// Blob ロケータを取得 ..
myStatement = myConnect.createStatement();
rs = myStatement.executeQuery(selectBlob);
while (rs.next()) {
myRegularBlob = rs.getBlob("blobCol");
}
// 記述用の基底の Oracle 拡張機能にアクセスする // OracleThinBlob インタフェースをキャストして、
// Oracle メソッドにアクセスする
os = ((OracleThinBlob)myRegularBlob).getBinaryOutputStream();
...
...
} catch (SQLException sqe) {
System.out.println("ERROR(general SQE): " + sqe.getMessage());
}
Oracle.ThinBlob インタフェースをキャストしたら、BEA がサポートするメソッ
ドにアクセスできます。Prepared Statement を使用した CLOB 値の更新
Prepared Statement を使用して CLOB を更新する場合、新しい値が古い値より短
いと、更新の際に明示的に置換されなかった文字が CLOB に残ります。たとえ ば、現在の値が abcdefghijである CLOB を Prepared Statement で
zxywという
値に更新すると、更新後の CLOB の値は zxywefghijになります。Prepared
Statement で更新した結果を正しい値にするには、
dbms_lob.trimプロシージャ
を使って、更新後に残っている余分な文字を削除する必要があります。
dbms_lob.trim
プロシージャの詳細については、Oracle のマニュアルを参照し
てください。Oracle Thin Driver の拡張機能
以下の表に、Oracle インタフェースを示します。
Oracle 拡張機能およびサポートされるメソッド
以下の表に Oracle インタフェースを示します。また、java.sql.*
インタフェー
スを拡張するために Oracle Thin Driver で使用するメソッドで、サポートされて いるものを示します。Blob/Clob インタフェースについては、6-17ページの「Oracle Blob/Clob インタフェースにアクセスするサンプル コード」を参照して ください。
6 WebLogic Server でのサードパーティ ドライバの使い方
表6-3 OracleConnection インタフェース
拡張 メソッド シグネチャ
OracleConnection extends
java.sql.Connection
boolean getAutoClose()
throws java.sql.SQLException;
void setAutoClose(boolean on) throws java.sql.SQLException;
String getDatabaseProductVersion() throws java.sql.SQLException;
String getProtocolType() throws java.sql.SQLException;
String getURL() throws java.sql.SQLException;
String getUserName()
throws java.sql.SQLException;
boolean getBigEndian()
throws java.sql.SQLException;
boolean getDefaultAutoRefetch() throws java.sql.SQLException;
boolean getIncludeSynonyms()
throws java.sql.SQLException;
boolean getRemarksReporting()
throws java.sql.SQLException;
boolean getReportRemarks()
throws java.sql.SQLException;
boolean getRestrictGetTables() throws java.sql.SQLException;
boolean getUsingXAFlag()
throws java.sql.SQLException;
boolean getXAErrorFlag()
throws java.sql.SQLException;
Oracle Thin Driver の拡張機能
OracleConnection extends
java.sql.Connection
(続く)
byte[] getFDO(boolean b)
throws java.sql.SQLException;
int getDefaultExecuteBatch() throws java.sql.SQLException;
int getDefaultRowPrefetch()
throws java.sql.SQLException;
int getStmtCacheSize()
throws java.sql.SQLException;
java.util.Properties getDBAccessProperties() throws java.sql.SQLException;
short getDbCsId() throws java.sql.SQLException;
short getJdbcCsId() throws java.sql.SQLException;
short getStructAttrCsId()
throws java.sql.SQLException;
short getVersionNumber()
throws java.sql.SQLException;
void archive(int i, int j, String s) throws java.sql.SQLException;
void close_statements()
throws java.sql.SQLException;
void initUserName() throws java.sql.SQLException;
void logicalClose() throws java.sql.SQLException;
void needLine() throws java.sql.SQLException;
void printState() throws java.sql.SQLException;
void registerSQLType(String s, String t) throws java.sql.SQLException;
void releaseLine() throws java.sql.SQLException;
表6-3 OracleConnection インタフェース(続き)
拡張 メソッド シグネチャ
6 WebLogic Server でのサードパーティ ドライバの使い方
注意: サービス パック 4 では、次のメソッドが削除されました。
isCompatibleTo816() OracleConnection
extends
java.sql.Connection
(続く)
void removeAllDescriptor()
throws java.sql.SQLException;
// これは Sun の綴り
void removeDecriptor(String s) throws java.sql.SQLException;
void setDefaultAutoRefetch(boolean b) throws java.sql.SQLException;
void setDefaultExecuteBatch(int i) throws java.sql.SQLException;
void setDefaultRowPrefetch(int i) throws java.sql.SQLException;
void setFDO(byte[] b)
throws java.sql.SQLException;
void setIncludeSynonyms(boolean b) throws java.sql.SQLException;
void setPhysicalStatus(boolean b) throws java.sql.SQLException;
void setRemarksReporting(boolean b) throws java.sql.SQLException;
void setRestrictGetTables(boolean b) throws java.sql.SQLException;
void setStmtCacheSize(int i)
throws java.sql.SQLException;
void setStmtCacheSize(int i, boolean b) throws java.sql.SQLException;
void setUsingXAFlag(boolean b) throws java.sql.SQLException;
void setXAErrorFlag(boolean b) throws java.sql.SQLException;
void shutdown(int i)
throws java.sql.SQLException;
void startup(String s, int i)
throws java.sql.SQLException;
表6-3 OracleConnection インタフェース(続き)
拡張 メソッド シグネチャ
Oracle Thin Driver の拡張機能
注意 サービス パック 4 では、次のメソッドが削除されました。
表6-4 OracleStatement インタフェース
拡張 メソッド シグネチャ
OracleStatement extends
java.sql.statement
String getOriginalSql()
throws java.sql.SQLException;
String getRevisedSql()
throws java.sql.SQLException;
boolean getAutoRefetch()
throws java.sql.SQLException;
boolean is_value_null(boolean b, int i) throws java.sql.SQLException;
byte getSqlKind()
throws java.sql.SQLException;
int creationState()
throws java.sql.SQLException;
int getRowPrefetch()
throws java.sql.SQLException;
int sendBatch()
throws java.sql.SQLException;
void clearDefines()
throws java.sql.SQLException;
void defineColumnType(int i, int j) throws java.sql.SQLException;
void defineColumnType(int i, int j, String s) throws java.sql.SQLException;
OracleStatement extends
java.sql.statement
(続く)
void defineColumnType(int i, int j, int k) throws java.sql.SQLException;
void describe() throws java.sql.SQLException;
void notify_close_rset() throws java.sql.SQLException;
void setAutoRefetch(boolean b) throws java.sql.SQLException;
void setRowPrefetch(int i)
throws java.sql.SQLException;
6 WebLogic Server でのサードパーティ ドライバの使い方
getWaitOption()
setWaitOption(int i)
setAutoRollback(int i)
getAutoRollback()
注意: サービス パック 4 では、次のメソッドが削除されました。
getCURSOR(String s) 表6-5 OracleResultSet インタフェース
拡張 メソッド シグネチャ
OracleResultSet extends
java.sql.ResultSet
boolean getAutoRefetch() throws java.sql.SQLException;
int getFirstUserColumnIndex() throws java.sql.SQLException;
void closeStatementOnClose() throws java.sql.SQLException;
void setAutoRefetch(boolean b) throws java.sql.SQLException;
java.sql.ResultSet getCursor(int n) throws java.sql.SQLException;
Oracle Thin Driver の拡張機能
表6-6 OracleCallableStatement インタフェース
拡張 メソッド シグネチャ
OracleCallableState ment
extends java.sql.
CallableStatement
void clearParameters()
throws java.sql.SQLException;
void registerIndexTableOutParameter(int i, int j, int k, int l)
throws java.sql.SQLException;
void registerOutParameter
(int i, int j, int k, int l) throws java.sql.SQLException;
java.sql.ResultSet getCursor(int i) throws java.sql.SQLException;
java.io.InputStream getAsciiStream(int i) throws java.sql.SQLException;
java.io.InputStream getBinaryStream(int i) throws java.sql.SQLException;
java.io.InputStream getUnicodeStream(int i) throws java.sql.SQLException;
表6-7 OraclePreparedStatement インタフェース
拡張 メソッド シグネチャ
OraclePreparedState ment
extends
OracleStatement and java.sql.
PreparedStatement
int getExecuteBatch()
throws java.sql.SQLException;
void defineParameterType(int i, int j, int k) throws java.sql.SQLException;
void setDisableStmtCaching(boolean b) throws java.sql.SQLException;
void setExecuteBatch(int i)
throws java.sql.SQLException;
void setFixedCHAR(int i, String s) throws java.sql.SQLException;
void setInternalBytes(int i, byte[] b, int j) throws java.sql.SQLException;
6 WebLogic Server でのサードパーティ ドライバの使い方
Oracle Blob/Clob 拡張機能とサポートされるメソッド
次の表に、java.sql.*
インタフェースの拡張機能を示します。
表6-8 OracleThinBlob インタフェース
拡張 メソッド シグネチャ
OracleThinBlob extends
java.sql.Blob
int getBufferSize()throws java.sql.Exception int getChunkSize()throws java.sql.Exception
int putBytes(long, int, byte[])throws java.sql.Exception int getBinaryOutputStream()throws java.sql.Exception
表6-9 OracleThinClob インタフェース
拡張 メソッド シグネチャ
OracleThinClob extends
java.sql.Clob
public OutputStream getAsciiOutputStream() throws java.sql.Exception;
public Writer getCharacterOutputStream() throws java.sql.Exception;
public int getBufferSize() throws java.sql.Exception;
public int getChunkSize() throws java.sql.Exception;
public char[] getChars(long l, int i) throws java.sql.Exception;
public int putChars(long start, char myChars[]) throws java.sql.Exception;
public int putString(long l, String s) throws java.sql.Exception;