Inserir CLOB no banco de dados Oracle

Minha pergunta é: Como você contorna oORA-01704: string literal too long erro ao inserir (ou fazer qualquer coisa em consultas) comCLOBs?

Eu quero ter uma consulta como esta:

INSERT ALL
   INTO mytable VALUES ('clob1')
   INTO mytable VALUES ('clob2') --some of these clobs are more than 4000 characters...
   INTO mytable VALUES ('clob3')
SELECT * FROM dual;

Quando eu tento com valores reais, embora eu tenhaORA-01704: string literal too long de volta. Isso é bastante óbvio, mas como eu insiro clobs (ou executo qualquer declaração com um clob)?

Eu tentei olhar para issoquestão, mas não acho que tenha o que estou procurando. Os clobs que tenho estão em umList<String> e eu faço uma iteração através deles para fazer a declaração. Meu código como segue é:

private void insertQueries(String tempTableName) throws FileNotFoundException, DataException, SQLException, IOException {
String preQuery = "  into " + tempTableName + " values ('";
String postQuery = "')" + StringHelper.newline;
StringBuilder inserts = new StringBuilder("insert all" + StringHelper.newline);
List<String> readQueries = getDomoQueries();
for (String query : readQueries) {
  inserts.append(preQuery).append(query).append(postQuery);
}
inserts.append("select * from dual;");

DatabaseController.getInstance().executeQuery(databaseConnectionURL, inserts.toString());

}

public ResultSet executeQuery(String connection, String query) throws DataException, SQLException {
  Connection conn = ConnectionPool.getInstance().get(connection);
  Statement stmt = conn.createStatement();
  ResultSet rs = stmt.executeQuery(query);
  conn.commit();
  ConnectionPool.getInstance().release(conn);
  return rs;
}

questionAnswers(6)

yourAnswerToTheQuestion