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.sql.CallableStatement;
19 import java.sql.PreparedStatement;
20 import java.sql.ResultSet;
21 import java.sql.SQLException;
22
23 import org.apache.ibatis.executor.result.ResultMapException;
24 import org.apache.ibatis.session.Configuration;
25
26
27
28
29
30
31
32
33
34
35
36
37
38 public abstract class BaseTypeHandler<T> extends TypeReference<T> implements TypeHandler<T> {
39
40
41
42
43 @Deprecated
44 protected Configuration configuration;
45
46
47
48
49
50
51
52
53 @Deprecated
54 public void setConfiguration(Configuration c) {
55 this.configuration = c;
56 }
57
58 @Override
59 public void setParameter(PreparedStatement ps, int i, T parameter, JdbcType jdbcType) throws SQLException {
60 if (parameter == null) {
61 if (jdbcType == null) {
62 throw new TypeException("JDBC requires that the JdbcType must be specified for all nullable parameters.");
63 }
64 try {
65 ps.setNull(i, jdbcType.TYPE_CODE);
66 } catch (SQLException e) {
67 throw new TypeException("Error setting null for parameter #" + i + " with JdbcType " + jdbcType + " . "
68 + "Try setting a different JdbcType for this parameter or a different jdbcTypeForNull configuration property. "
69 + "Cause: " + e, e);
70 }
71 } else {
72 try {
73 setNonNullParameter(ps, i, parameter, jdbcType);
74 } catch (Exception e) {
75 throw new TypeException("Error setting non null for parameter #" + i + " with JdbcType " + jdbcType + " . "
76 + "Try setting a different JdbcType for this parameter or a different configuration property. "
77 + "Cause: " + e, e);
78 }
79 }
80 }
81
82 @Override
83 public T getResult(ResultSet rs, String columnName) throws SQLException {
84 try {
85 return getNullableResult(rs, columnName);
86 } catch (Exception e) {
87 throw new ResultMapException("Error attempting to get column '" + columnName + "' from result set. Cause: " + e, e);
88 }
89 }
90
91 @Override
92 public T getResult(ResultSet rs, int columnIndex) throws SQLException {
93 try {
94 return getNullableResult(rs, columnIndex);
95 } catch (Exception e) {
96 throw new ResultMapException("Error attempting to get column #" + columnIndex + " from result set. Cause: " + e, e);
97 }
98 }
99
100 @Override
101 public T getResult(CallableStatement cs, int columnIndex) throws SQLException {
102 try {
103 return getNullableResult(cs, columnIndex);
104 } catch (Exception e) {
105 throw new ResultMapException("Error attempting to get column #" + columnIndex + " from callable statement. Cause: " + e, e);
106 }
107 }
108
109 public abstract void setNonNullParameter(PreparedStatement ps, int i, T parameter, JdbcType jdbcType) throws SQLException;
110
111
112
113
114
115
116
117
118
119
120
121
122 public abstract T getNullableResult(ResultSet rs, String columnName) throws SQLException;
123
124 public abstract T getNullableResult(ResultSet rs, int columnIndex) throws SQLException;
125
126 public abstract T getNullableResult(CallableStatement cs, int columnIndex) throws SQLException;
127
128 }