View Javadoc
1   /*
2    * Copyright 2004-2025 the original author or authors.
3    *
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    *    https://www.apache.org/licenses/LICENSE-2.0
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13   * See the License for the specific language governing permissions and
14   * limitations under the License.
15   */
16  package com.ibatis.sqlmap.engine.type;
17  
18  import com.ibatis.sqlmap.client.extensions.ParameterSetter;
19  import com.ibatis.sqlmap.client.extensions.ResultGetter;
20  import com.ibatis.sqlmap.client.extensions.TypeHandlerCallback;
21  
22  import java.io.StringReader;
23  import java.sql.Clob;
24  import java.sql.SQLException;
25  import java.sql.Types;
26  
27  /**
28   * The Class ClobTypeHandlerCallback.
29   */
30  public class ClobTypeHandlerCallback implements TypeHandlerCallback {
31  
32    @Override
33    public Object getResult(ResultGetter getter) throws SQLException {
34      String value;
35      Clob clob = getter.getClob();
36      if (!getter.wasNull()) {
37        int size = (int) clob.length();
38        value = clob.getSubString(1, size);
39      } else {
40        value = null;
41      }
42  
43      return value;
44    }
45  
46    @Override
47    public void setParameter(ParameterSetter setter, Object parameter) throws SQLException {
48      String s = (String) parameter;
49      if (s != null) {
50        StringReader reader = new StringReader(s);
51        setter.setCharacterStream(reader, s.length());
52      } else {
53        setter.setNull(Types.CLOB);
54      }
55    }
56  
57    @Override
58    public Object valueOf(String s) {
59      return s;
60    }
61  
62  }