View Javadoc
1   /*
2    *    Copyright 2009-2021 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    *       http://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 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  import java.sql.SQLXML;
23  
24  /**
25   * Convert <code>String</code> to/from <code>SQLXML</code>.
26   *
27   * @since 3.5.0
28   * @author Iwao AVE!
29   */
30  public class SqlxmlTypeHandler extends BaseTypeHandler<String> {
31  
32    @Override
33    public void setNonNullParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType)
34        throws SQLException {
35      SQLXML sqlxml = ps.getConnection().createSQLXML();
36      try {
37        sqlxml.setString(parameter);
38        ps.setSQLXML(i, sqlxml);
39      } finally {
40        sqlxml.free();
41      }
42    }
43  
44    @Override
45    public String getNullableResult(ResultSet rs, String columnName) throws SQLException {
46      return sqlxmlToString(rs.getSQLXML(columnName));
47    }
48  
49    @Override
50    public String getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
51      return sqlxmlToString(rs.getSQLXML(columnIndex));
52    }
53  
54    @Override
55    public String getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
56      return sqlxmlToString(cs.getSQLXML(columnIndex));
57    }
58  
59    protected String sqlxmlToString(SQLXML sqlxml) throws SQLException {
60      if (sqlxml == null) {
61        return null;
62      }
63      try {
64        return sqlxml.getString();
65      } finally {
66        sqlxml.free();
67      }
68    }
69  
70  }