我怎么能避免这个java.sql.SQLException:ORA-01704:字符串文字太长了?

时间:2015-06-10 15:45:59

标签: java sql oracle oracle11g ora-01704

我正在研究一个旧的遗留Java应用程序,我在这个方法上遇到了一些问题,它在Oracle数据库上执行简单的插入查询:

private boolean insertFlussoXmlsdi(DBOperatore op, String numeroFattura, String dataFattura, String fatturaXml) {

    StringBuffer query = new StringBuffer();

    query.append("INSERT INTO FLUSSO_XMLSDI (NUMERO_FATTURA, DATA_EMISSIONE, XML) VALUES (");
    query.append(numeroFattura);
    query.append(", date'");
    query.append(dataFattura);
    query.append("', '");
    query.append(fatturaXml);
    query.append("')");


    try {
        Statement stmt = op.getConnessione().createStatement();
        stmt.execute(query.toString());

    } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();

        TraceLog.scrivi("INSERIMENTO FATTURA", "ERRORE inserimento fattura con numero fattura: " + numeroFattura, false, TraceLog.lowConsole + TraceLog.highTrace + TraceLog.highLog);

        return false;
    }

    TraceLog.scrivi("INSERIMENTO FATTURA", "Inserimento fattura con numero fattura: " + numeroFattura, false, TraceLog.lowConsole + TraceLog.highTrace + TraceLog.highLog);

    return true;

}    

问题是 String fatturaXml 参数表示一个XML文件,它非常大。因此,当执行上一个查询时,我获得抛出此异常:

java.sql.SQLException: ORA-01704: string literal too long

如何解决此问题并正确插入记录?

TNX

2 个答案:

答案 0 :(得分:1)

如果有人试图将大于4000个字符的数据插入到列 - VARCHAR2中,则会出现错误ORA-01704。检查以下SO帖子

Error : ORA-01704: string literal too long

答案 1 :(得分:0)

您可以使用我在IBM大型机上使用的非常古老的方法来存储大数据:将字符串拆分为块,存储块:

CREATE TABLE mystore(referenceid int, somecounter int, data varchar(255));

循环:

public void insertSomeData(Connection connection,String inputData,int referenceId) {
    int i=0;
    String insertSql="INSERT INTO mystore (referenceid,somecounter,data) VALUES (?,?,?)";
    PreparedStatement pstmt=connection.prepareStatement(insertSql);
    int i=0;
    boolean keepGoing=true;
    while(keepGoing) {
        // Take 120 bytes only: Just in case of double byte encoding
        String substr=new String();
        if(inputData.length()>120) {
            substr=inputData.substring(0,120);
            inputData=inputData.substring(120);
        }
        else {
            substr=inputData;
            // Lets get out of this loop
            keepGoing=false;
        }
        pstmt.setInt(1,referenceId);
        pstmt.setInt(2,i);
        pstmt.setString(3,substr);
        pstmt.execute();
        pstmt.clearBatch();
        i++;
    }
    pstmt.close();
}

P.S。不要使用query.append代码:它对SQL注入和非转义数据很敏感。请改用PreparedStatement。