1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package org.apache.ibatis.type;
17
18 import java.io.StringReader;
19 import java.sql.CallableStatement;
20 import java.sql.NClob;
21 import java.sql.PreparedStatement;
22 import java.sql.ResultSet;
23 import java.sql.SQLException;
24
25
26
27
28 public class NClobTypeHandler extends BaseTypeHandler<String> {
29
30 @Override
31 public void setNonNullParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType)
32 throws SQLException {
33 StringReader reader = new StringReader(parameter);
34 ps.setNCharacterStream(i, reader, parameter.length());
35 }
36
37 @Override
38 public String getNullableResult(ResultSet rs, String columnName) throws SQLException {
39 NClob nclob = rs.getNClob(columnName);
40 return toString(nclob);
41 }
42
43 @Override
44 public String getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
45 NClob nclob = rs.getNClob(columnIndex);
46 return toString(nclob);
47 }
48
49 @Override
50 public String getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
51 NClob nclob = cs.getNClob(columnIndex);
52 return toString(nclob);
53 }
54
55 private String toString(NClob nclob) throws SQLException {
56 return nclob == null ? null : nclob.getSubString(1, (int) nclob.length());
57 }
58
59 }