From 2cf0eaca2132d9f2a5c72d56ddf67f26a8f465d8 Mon Sep 17 00:00:00 2001 From: artaxerxe Date: Fri, 11 Jun 2021 12:48:13 +0300 Subject: [PATCH] Revert "OPENJPA-2745: Clean up try-catch implementation for DB2Dictionary" This reverts commit fadcf7652fb8660b7374187bc5e50e636772a6ab. --- .../openjpa/jdbc/sql/DB2Dictionary.java | 38 +++++++++++-------- 1 file changed, 23 insertions(+), 15 deletions(-) diff --git a/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/sql/DB2Dictionary.java b/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/sql/DB2Dictionary.java index 523b9ae54..eaea440e3 100644 --- a/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/sql/DB2Dictionary.java +++ b/openjpa-jdbc/src/main/java/org/apache/openjpa/jdbc/sql/DB2Dictionary.java @@ -1023,22 +1023,30 @@ public class DB2Dictionary return (byte[]) rs.getObject(column); } - int type = rs.getMetaData().getColumnType(column); - switch (type) { - case Types.BLOB: - Blob blob = getBlob(rs, column); - if (blob == null) { - return null; - } - - int length = (int) blob.length(); - if (length == 0) { - return null; - } - return blob.getBytes(1, length); - case Types.BINARY: - default: + // At this point we don't have any idea if the DB2 column was defined as + // a blob or if it was defined as CHAR for BIT DATA. + // First try as a blob, if that doesn't work, then try as CHAR for BIT DATA + // If that doesn't work, then go ahead and throw the first exception + try { + Blob blob = getBlob(rs, column); + if (blob == null) { + return null; + } + + int length = (int) blob.length(); + if (length == 0) { + return null; + } + + return blob.getBytes(1, length); + } + catch (SQLException e) { + try { return rs.getBytes(column); + } + catch (SQLException e2) { + throw e; + } } }