This week's book giveaway is in the Cloud forum.
We're giving away four copies of Terraform in Action and have Scott Winkler on-line!
See this thread for details.
Win a copy of Terraform in Action this week in the Cloud forum!
  • Post Reply Bookmark Topic Watch Topic
  • New Topic
programming forums Java Mobile Certification Databases Caching Books Engineering Micro Controllers OS Languages Paradigms IDEs Build Tools Frameworks Application Servers Open Source This Site Careers Other Pie Elite all forums
this forum made possible by our volunteer staff, including ...
Marshals:
  • Tim Cooke
  • Campbell Ritchie
  • Paul Clapham
  • Ron McLeod
  • Liutauras Vilda
Sheriffs:
  • Jeanne Boyarsky
  • Rob Spoor
  • Bear Bibeault
Saloon Keepers:
  • Jesse Silverman
  • Tim Moores
  • Stephan van Hulst
  • Tim Holloway
  • Carey Brown
Bartenders:
  • Piet Souris
  • Al Hobbs
  • salvin francis

Insert a 7k String into Oracle CLOB?

 
Ranch Hand
Posts: 38
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
I've been struggling to store a huge string (7k) into an Oracle CLOB column.

This is what I have tried so far:

1.

<blockquote>code:
<pre name="code" class="java">String toStore="a long string" ;
Reader sReader = new StringReader(toStore);
int readerLength = toStore.toCharArray().length;
insertStatement.setCharacterStream(2, sReader, readerLength);
</pre>
</blockquote>


This inserts junk characters into the table with both thin and oci drivers.

2.

<blockquote>code:
<pre name="code" class="java">CLOB clob = CLOB.createTemporary(connection, true, oracle.sql.CLOB.DURATION_SESSION);
clob.trim(0);
Writer writer = clob.getCharacterOutputStream();
writer.write(toStore.toCharArray());
writer.flush();
writer.close();
insertStatement.setCLOB(2, clob);
</pre>
</blockquote>


This fails with ORA-12704: character set mismatch

3.

This consists of two steps:
a) Insert EMPTY_CLOB() into clob table
b) Select the CLOB column from the table for update and then:

<blockquote>code:
<pre name="code" class="java">oracle.sql.CLOB clob = ((oracle.jdbc.OracleResultSet) resultSet).getCLOB("clob_column");
Writer writer = clob.getCharacterOutputStream();
writer.write(toStore.toCharArray());
writer.flush();
writer.close();
</pre>
</blockquote>

This one works perfectly, but with the overhead of two calls to the database.

Does anyone have any neater way of storing a large clob object?

Any help would be appreciated!

Thanks
 
Fahd Shariff
Ranch Hand
Posts: 38
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
I have tried various methods and finally found a couple of solutions to this problem. Please read my blog, to find out everything I tried as it is too much to post here:

Big Strings and Oracle Clobs
 
author
Posts: 4278
34
jQuery Eclipse IDE Java
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Still confused about what you mean by junk characters... is it possible it just converted to a different character encoding? Did you check the character encoding properties of the database? I would think attempt #4 (setCharacterStream) would work fine if you set the encoding properly.
[ July 16, 2008: Message edited by: Scott Selikoff ]
 
Ranch Hand
Posts: 425
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
You could have used setAsciiStream API in prepared statement interface. CLOB is specific to Oracle
 
Scott Selikoff
author
Posts: 4278
34
jQuery Eclipse IDE Java
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Good point Purushothaman. Clobs are fine from a database-perspective, but most JDBC developers skip Clobs and rely on Blob/Stream interface methods.
 
Fahd Shariff
Ranch Hand
Posts: 38
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
I tried using setAsciiStream, but that produced junk as well:

ByteArrayInputStream bis = new ByteArrayInputStream(bigString.getBytes());
st.setAsciiStream(1, bis, bigString.getBytes().length);
 
Fahd Shariff
Ranch Hand
Posts: 38
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
This is the junk I get back. Could be a different character set. Is there any way I can set the character set in jdbc? My Oracle NLS_CHARACTERSET is WE8ISO8859P1.

�������������������������>�����������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������>������������������������������������>������������������������������������>������������������>���������������������������������������������������������>������������������>������������������>��� ���������������������������������>������������������������������������>������������������>������������������������������������>������������������������������������>������������������������������������>������������������������������������>������������������������������������>������������������>��������������������������������������>�������������������������������������������������������>������������������>�����������������>����������������������������������� �>������������������>������������������������������������>�����������������������������������>����������������������������������������������������������������������������������������������������������������>����������������������������������>������������������������������������>��������������������������������������������������������������������������������������������>�����������������>�����������������>������������������>�����������������>������������������& gt;�������������������/�������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������'������������������������������������������������������������������������������������������������������������������������������������������������������� ����������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������>������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������ �������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������� �����������������������������>������������>������������>������������>�������>������������>������������>������������>������������>������������>������������>������������>������������>������������>������������>��������������������>������������>������������>������������>������������>������������>������������>������������>�������>������������>������������>������������>������������>������������>������������>����� �������>�������������������������������������������������������������������������������>������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������������>�������������������������>����������������������������������������������>��������������������������������������������������������������������>��������������������������
 
You showed up just in time for the waffles! And this tiny ad:
Building a Better World in your Backyard by Paul Wheaton and Shawn Klassen-Koop
https://coderanch.com/wiki/718759/books/Building-World-Backyard-Paul-Wheaton
reply
    Bookmark Topic Watch Topic
  • New Topic