From df1e019ab09b9b8bde1b4d511e1c2cae857f9783 Mon Sep 17 00:00:00 2001 From: Alex Bogdanovski Date: Thu, 1 Aug 2024 16:20:58 +0300 Subject: [PATCH] fixed error when inserting large text values in Oracle DB, by properly utilizing JDBC's CLOB type --- .../para/server/persistence/SqlUtils.java | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/erudika/para/server/persistence/SqlUtils.java b/src/main/java/com/erudika/para/server/persistence/SqlUtils.java index 2e1fc86..131302f 100755 --- a/src/main/java/com/erudika/para/server/persistence/SqlUtils.java +++ b/src/main/java/com/erudika/para/server/persistence/SqlUtils.java @@ -31,6 +31,7 @@ import com.zaxxer.hikari.HikariDataSource; import java.sql.Connection; import java.sql.DriverManager; +import java.sql.NClob; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; @@ -362,7 +363,13 @@ protected static

void createRows(String appid, List

ob } else { ps.setNull(3, Types.NULL); } - ps.setString(4, objectJson); + if (useOrSqlSyntax) { + NClob clob = connection.createNClob(); + clob.setString(1, objectJson); + ps.setClob(4, clob); + } else { + ps.setString(4, objectJson); + } if (useMySqlSyntax || usePGSqlSyntax || useLiSqlSyntax) { ps.setString(5, object.getType()); @@ -408,7 +415,14 @@ protected static

void updateRows(String appid, List

ob if (object != null && !StringUtils.isBlank(object.getId())) { object.setUpdated(Utils.timestamp()); Map data = ParaObjectUtils.getAnnotatedFields(object, Locked.class, false); - ps.setString(1, ParaObjectUtils.getJsonWriterNoIdent().writeValueAsString(data)); + String objectJson = ParaObjectUtils.getJsonWriterNoIdent().writeValueAsString(data); + if (useOrSqlSyntax) { + NClob clob = connection.createNClob(); + clob.setString(1, objectJson); + ps.setClob(1, clob); + } else { + ps.setString(1, objectJson); + } ps.setString(2, object.getId()); ps.addBatch(); }