提交 4e322744 编写于 作者: J Juergen Hoeller

DefaultLobHandler's "wrapAsLob" mode works with PostgreSQL's getAsciiStream()...

DefaultLobHandler's "wrapAsLob" mode works with PostgreSQL's getAsciiStream() requirement (SPR-7487)
上级 e56cfb81
/*
* 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");
* you may not use this file except in compliance with the License.
......@@ -237,7 +237,7 @@ public class DefaultLobHandler extends AbstractLobHandler {
}
public void setClobAsString(PreparedStatement ps, int paramIndex, String content)
throws SQLException {
throws SQLException {
if (streamAsLob) {
if (content != null) {
......@@ -266,17 +266,16 @@ public class DefaultLobHandler extends AbstractLobHandler {
public void setClobAsAsciiStream(
PreparedStatement ps, int paramIndex, InputStream asciiStream, int contentLength)
throws SQLException {
throws SQLException {
if (streamAsLob || wrapAsLob) {
if (asciiStream != null) {
try {
Reader reader = new InputStreamReader(asciiStream, "US-ASCII");
if (streamAsLob) {
ps.setClob(paramIndex, reader, contentLength);
ps.setClob(paramIndex, new InputStreamReader(asciiStream, "US-ASCII"), contentLength);
}
else {
ps.setClob(paramIndex, new PassThroughClob(reader, contentLength));
ps.setClob(paramIndex, new PassThroughClob(asciiStream, contentLength));
}
}
catch (UnsupportedEncodingException ex) {
......@@ -298,7 +297,7 @@ public class DefaultLobHandler extends AbstractLobHandler {
public void setClobAsCharacterStream(
PreparedStatement ps, int paramIndex, Reader characterStream, int contentLength)
throws SQLException {
throws SQLException {
if (streamAsLob) {
if (characterStream != null) {
......
/*
* 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");
* you may not use this file except in compliance with the License.
......@@ -69,7 +69,7 @@ public interface LobCreator {
* @see java.sql.PreparedStatement#setBytes
*/
void setBlobAsBytes(PreparedStatement ps, int paramIndex, byte[] content)
throws SQLException;
throws SQLException;
/**
* Set the given content as binary stream on the given statement, using the given
......@@ -83,7 +83,7 @@ public interface LobCreator {
*/
void setBlobAsBinaryStream(
PreparedStatement ps, int paramIndex, InputStream contentStream, int contentLength)
throws SQLException;
throws SQLException;
/**
* Set the given content as String on the given statement, using the given
......@@ -96,7 +96,7 @@ public interface LobCreator {
* @see java.sql.PreparedStatement#setBytes
*/
void setClobAsString(PreparedStatement ps, int paramIndex, String content)
throws SQLException;
throws SQLException;
/**
* Set the given content as ASCII stream on the given statement, using the given
......@@ -110,7 +110,7 @@ public interface LobCreator {
*/
void setClobAsAsciiStream(
PreparedStatement ps, int paramIndex, InputStream asciiStream, int contentLength)
throws SQLException;
throws SQLException;
/**
* Set the given content as character stream on the given statement, using the given
......@@ -124,7 +124,7 @@ public interface LobCreator {
*/
void setClobAsCharacterStream(
PreparedStatement ps, int paramIndex, Reader characterStream, int contentLength)
throws SQLException;
throws SQLException;
/**
* Close this LobCreator session and free its temporarily created BLOBs and CLOBs.
......
/*
* 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");
* 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 {
throw new UnsupportedOperationException();
// no-op
}
}
/*
* 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");
* you may not use this file except in compliance with the License.
......@@ -16,14 +16,20 @@
package org.springframework.jdbc.support.lob;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.Reader;
import java.io.StringReader;
import java.io.UnsupportedEncodingException;
import java.io.Writer;
import java.sql.Clob;
import java.sql.SQLException;
import org.springframework.util.FileCopyUtils;
/**
* Simple JDBC {@link Clob} adapter that exposes a given String or character stream.
* Optionally used by {@link DefaultLobHandler}.
......@@ -37,6 +43,8 @@ class PassThroughClob implements Clob {
private Reader characterStream;
private InputStream asciiStream;
private long contentLength;
......@@ -50,13 +58,52 @@ class PassThroughClob implements Clob {
this.contentLength = contentLength;
}
public PassThroughClob(InputStream asciiStream, long contentLength) {
this.asciiStream = asciiStream;
this.contentLength = contentLength;
}
public long length() throws SQLException {
return this.contentLength;
}
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();
}
public InputStream getAsciiStream() throws SQLException {
return null;
}
public OutputStream setAsciiStream(long pos) throws SQLException {
throw new UnsupportedOperationException();
}
......@@ -101,7 +144,7 @@ class PassThroughClob implements Clob {
}
public void free() throws SQLException {
throw new UnsupportedOperationException();
// no-op
}
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册