|
@@ -1,5 +1,6 @@
|
|
|
package com.uas.erp.database.repository;
|
|
|
|
|
|
+import oracle.sql.CLOB;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.dao.DataAccessException;
|
|
|
import org.springframework.dao.EmptyResultDataAccessException;
|
|
@@ -9,10 +10,10 @@ import org.springframework.jdbc.core.JdbcTemplate;
|
|
|
import org.springframework.jdbc.core.RowMapper;
|
|
|
import org.springframework.stereotype.Repository;
|
|
|
|
|
|
-import java.sql.CallableStatement;
|
|
|
-import java.sql.ResultSet;
|
|
|
-import java.sql.SQLException;
|
|
|
-import java.sql.Types;
|
|
|
+import java.io.BufferedReader;
|
|
|
+import java.io.IOException;
|
|
|
+import java.io.Reader;
|
|
|
+import java.sql.*;
|
|
|
import java.util.HashMap;
|
|
|
import java.util.List;
|
|
|
import java.util.Map;
|
|
@@ -70,7 +71,12 @@ public class BaseRepository {
|
|
|
Map<String, Object> data = new HashMap<>();
|
|
|
for (String field : fields) {
|
|
|
try {
|
|
|
- data.put(field, rs.getObject(field));
|
|
|
+
|
|
|
+ if (rs.getObject(field) instanceof CLOB) {
|
|
|
+ data.put(field, ClobToString(rs.getClob(field)));
|
|
|
+ } else {
|
|
|
+ data.put(field, rs.getObject(field));
|
|
|
+ }
|
|
|
} catch (SQLException e) {
|
|
|
|
|
|
}
|
|
@@ -83,6 +89,41 @@ public class BaseRepository {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+
|
|
|
+ * clob字段转String
|
|
|
+ * @param clob
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ public String ClobToString(Clob clob) {
|
|
|
+ String reString = "";
|
|
|
+ Reader is = null;
|
|
|
+ try {
|
|
|
+ is = clob.getCharacterStream();
|
|
|
+ } catch (SQLException e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+
|
|
|
+ BufferedReader br = new BufferedReader(is);
|
|
|
+ String s = null;
|
|
|
+ try {
|
|
|
+ s = br.readLine();
|
|
|
+ } catch (IOException e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ StringBuffer sb = new StringBuffer();
|
|
|
+ while (s != null) {
|
|
|
+
|
|
|
+ sb.append(s);
|
|
|
+ try {
|
|
|
+ s = br.readLine();
|
|
|
+ } catch (IOException e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ reString = sb.toString();
|
|
|
+ return reString;
|
|
|
+ }
|
|
|
+
|
|
|
public <T> List<T> queryForList(String exec, Class<T> targetCls, Object... vars) {
|
|
|
try {
|
|
|
return jdbcTemplate.queryForList(exec, targetCls, vars);
|