From 449e203fff4fd3b108061cfb5ad2e20a8114e799 Mon Sep 17 00:00:00 2001 From: Corey Winkelmann Date: Thu, 14 Nov 2024 08:51:12 -0700 Subject: [PATCH] refactor(schema): add database filtering to JSON detection --- .../maxwell/schema/SchemaCapturer.java | 48 ++++++++++--------- 1 file changed, 26 insertions(+), 22 deletions(-) diff --git a/src/main/java/com/zendesk/maxwell/schema/SchemaCapturer.java b/src/main/java/com/zendesk/maxwell/schema/SchemaCapturer.java index b9233c828..c7035ec9b 100644 --- a/src/main/java/com/zendesk/maxwell/schema/SchemaCapturer.java +++ b/src/main/java/com/zendesk/maxwell/schema/SchemaCapturer.java @@ -139,7 +139,9 @@ public Schema capture() throws SQLException { Schema s = new Schema(databases, captureDefaultCharset(), this.sensitivity); try { if ( isMariaDB() && mariaSupportsJSON()) { - detectMariaDBJSON(s); + for (String dbName : s.getDatabaseNames()) { + detectMariaDBJSON(s, dbName); + } } } catch ( InvalidSchemaError e ) { e.printStackTrace(); @@ -315,38 +317,40 @@ public void close() throws SQLException { } } - private void detectMariaDBJSON(Schema schema) throws SQLException, InvalidSchemaError { + private void detectMariaDBJSON(Schema schema, String dbName) throws SQLException, InvalidSchemaError { String checkConstraintSQL = "SELECT CONSTRAINT_SCHEMA, TABLE_NAME, CONSTRAINT_NAME, CHECK_CLAUSE " + "from INFORMATION_SCHEMA.CHECK_CONSTRAINTS " + - "where CHECK_CLAUSE LIKE 'json_valid(%)'"; + "where CONSTRAINT_SCHEMA = ? AND CHECK_CLAUSE LIKE 'json_valid(%)'"; String regex = "json_valid\\(`(.*)`\\)"; Pattern pattern = Pattern.compile(regex); try ( - PreparedStatement statement = connection.prepareStatement(checkConstraintSQL); - ResultSet rs = statement.executeQuery() - ) { - while ( rs.next() ) { - String checkClause = rs.getString("CHECK_CLAUSE"); - Matcher m = pattern.matcher(checkClause); - if ( m.find() ) { - String column = m.group(1); - Database d = schema.findDatabase(rs.getString("CONSTRAINT_SCHEMA")); - if ( d == null ) continue; - Table t = d.findTable(rs.getString("TABLE_NAME")); - if ( t == null ) continue; - short i = t.findColumnIndex(column); - if ( i < 0 ) continue; - - ColumnDef cd = t.findColumn(i); - if ( cd instanceof StringColumnDef ) { - t.replaceColumn(i, JsonColumnDef.create(cd.getName(), "json", i)); + PreparedStatement statement = connection.prepareStatement(checkConstraintSQL)) { + statement.setString(1, dbName); + + try ( + ResultSet rs = statement.executeQuery()) { + while ( rs.next() ) { + String checkClause = rs.getString("CHECK_CLAUSE"); + Matcher m = pattern.matcher(checkClause); + if ( m.find() ) { + String column = m.group(1); + Database d = schema.findDatabase(rs.getString("CONSTRAINT_SCHEMA")); + if ( d == null ) continue; + Table t = d.findTable(rs.getString("TABLE_NAME")); + if ( t == null ) continue; + short i = t.findColumnIndex(column); + if ( i < 0 ) continue; + + ColumnDef cd = t.findColumn(i); + if ( cd instanceof StringColumnDef ) { + t.replaceColumn(i, JsonColumnDef.create(cd.getName(), "json", i)); + } } } } } - } }