DefaultLobHandler's "wrapAsLob" mode works with PostgreSQL's getAsciiStream() requirement (SPR-7487)
This commit is contained in:
parent
e56cfb8173
commit
4e3227441b
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2009 the original author or authors.
|
* Copyright 2002-2010 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
|
@ -271,12 +271,11 @@ public class DefaultLobHandler extends AbstractLobHandler {
|
||||||
if (streamAsLob || wrapAsLob) {
|
if (streamAsLob || wrapAsLob) {
|
||||||
if (asciiStream != null) {
|
if (asciiStream != null) {
|
||||||
try {
|
try {
|
||||||
Reader reader = new InputStreamReader(asciiStream, "US-ASCII");
|
|
||||||
if (streamAsLob) {
|
if (streamAsLob) {
|
||||||
ps.setClob(paramIndex, reader, contentLength);
|
ps.setClob(paramIndex, new InputStreamReader(asciiStream, "US-ASCII"), contentLength);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
ps.setClob(paramIndex, new PassThroughClob(reader, contentLength));
|
ps.setClob(paramIndex, new PassThroughClob(asciiStream, contentLength));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
catch (UnsupportedEncodingException ex) {
|
catch (UnsupportedEncodingException ex) {
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2008 the original author or authors.
|
* Copyright 2002-2010 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2008 the original author or authors.
|
* Copyright 2002-2010 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
|
@ -91,7 +91,7 @@ class PassThroughBlob implements Blob {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void free() throws SQLException {
|
public void free() throws SQLException {
|
||||||
throw new UnsupportedOperationException();
|
// no-op
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2008 the original author or authors.
|
* Copyright 2002-2010 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
|
@ -16,14 +16,20 @@
|
||||||
|
|
||||||
package org.springframework.jdbc.support.lob;
|
package org.springframework.jdbc.support.lob;
|
||||||
|
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.io.Reader;
|
import java.io.Reader;
|
||||||
import java.io.StringReader;
|
import java.io.StringReader;
|
||||||
|
import java.io.UnsupportedEncodingException;
|
||||||
import java.io.Writer;
|
import java.io.Writer;
|
||||||
import java.sql.Clob;
|
import java.sql.Clob;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
|
|
||||||
|
import org.springframework.util.FileCopyUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Simple JDBC {@link Clob} adapter that exposes a given String or character stream.
|
* Simple JDBC {@link Clob} adapter that exposes a given String or character stream.
|
||||||
* Optionally used by {@link DefaultLobHandler}.
|
* Optionally used by {@link DefaultLobHandler}.
|
||||||
|
|
@ -37,6 +43,8 @@ class PassThroughClob implements Clob {
|
||||||
|
|
||||||
private Reader characterStream;
|
private Reader characterStream;
|
||||||
|
|
||||||
|
private InputStream asciiStream;
|
||||||
|
|
||||||
private long contentLength;
|
private long contentLength;
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -50,13 +58,52 @@ class PassThroughClob implements Clob {
|
||||||
this.contentLength = contentLength;
|
this.contentLength = contentLength;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public PassThroughClob(InputStream asciiStream, long contentLength) {
|
||||||
|
this.asciiStream = asciiStream;
|
||||||
|
this.contentLength = contentLength;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public long length() throws SQLException {
|
public long length() throws SQLException {
|
||||||
return this.contentLength;
|
return this.contentLength;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Reader getCharacterStream() throws SQLException {
|
public Reader getCharacterStream() throws SQLException {
|
||||||
return (this.content != null ? new StringReader(this.content) : this.characterStream);
|
try {
|
||||||
|
if (this.content != null) {
|
||||||
|
return new StringReader(this.content);
|
||||||
|
}
|
||||||
|
else if (this.characterStream != null) {
|
||||||
|
return this.characterStream;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return new InputStreamReader(this.asciiStream, "US-ASCII");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (UnsupportedEncodingException ex) {
|
||||||
|
throw new SQLException("US-ASCII encoding not supported: " + ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public InputStream getAsciiStream() throws SQLException {
|
||||||
|
try {
|
||||||
|
if (this.content != null) {
|
||||||
|
return new ByteArrayInputStream(this.content.getBytes("US-ASCII"));
|
||||||
|
}
|
||||||
|
else if (this.characterStream != null) {
|
||||||
|
String tempContent = FileCopyUtils.copyToString(this.characterStream);
|
||||||
|
return new ByteArrayInputStream(tempContent.getBytes("US-ASCII"));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return this.asciiStream;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (UnsupportedEncodingException ex) {
|
||||||
|
throw new SQLException("US-ASCII encoding not supported: " + ex);
|
||||||
|
}
|
||||||
|
catch (IOException ex) {
|
||||||
|
throw new SQLException("Failed to read stream content: " + ex);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -68,10 +115,6 @@ class PassThroughClob implements Clob {
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
public InputStream getAsciiStream() throws SQLException {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public OutputStream setAsciiStream(long pos) throws SQLException {
|
public OutputStream setAsciiStream(long pos) throws SQLException {
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
@ -101,7 +144,7 @@ class PassThroughClob implements Clob {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void free() throws SQLException {
|
public void free() throws SQLException {
|
||||||
throw new UnsupportedOperationException();
|
// no-op
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue