From 11e08e77daec5781d7d55029a6c548fb5755480c Mon Sep 17 00:00:00 2001 From: hilary egesa Date: Wed, 25 Sep 2024 18:15:48 +0300 Subject: [PATCH] replace contentvalues with reusable SqliteStatement --- gradle.properties | 2 +- .../repository/DetailsRepository.java | 65 ++++++++++++++----- .../sync/ClientProcessorForJava.java | 4 +- 3 files changed, 52 insertions(+), 19 deletions(-) diff --git a/gradle.properties b/gradle.properties index 0eb048829..19d4dc6da 100644 --- a/gradle.properties +++ b/gradle.properties @@ -1,4 +1,4 @@ -VERSION_NAME=6.1.5-ALPHA29-SNAPSHOT +VERSION_NAME=6.1.5-ALPHA41-SNAPSHOT VERSION_CODE=1 GROUP=org.smartregister POM_SETTING_DESCRIPTION=OpenSRP Client Core Application diff --git a/opensrp-core/src/main/java/org/smartregister/repository/DetailsRepository.java b/opensrp-core/src/main/java/org/smartregister/repository/DetailsRepository.java index fd2fa4a72..79bc3471e 100644 --- a/opensrp-core/src/main/java/org/smartregister/repository/DetailsRepository.java +++ b/opensrp-core/src/main/java/org/smartregister/repository/DetailsRepository.java @@ -4,12 +4,12 @@ import android.database.Cursor; import net.sqlcipher.database.SQLiteDatabase; +import net.sqlcipher.database.SQLiteStatement; import org.smartregister.commonregistry.CommonPersonObject; import org.smartregister.commonregistry.CommonPersonObjectClient; import java.util.HashMap; -import java.util.List; import java.util.Map; import timber.log.Timber; @@ -34,7 +34,7 @@ protected void onCreate(SQLiteDatabase database) { } public void add(String baseEntityId, String key, String value, Long timestamp) { - SQLiteDatabase database = masterRepository().getWritableDatabase(); + SQLiteDatabase database = masterRepository().getReadableDatabase(); // long start = System.currentTimeMillis(); Boolean exists = getIdForDetailsIfExists(baseEntityId, key, value); // Timber.d("check if details exist's took %s, ", System.currentTimeMillis() - start); @@ -63,38 +63,71 @@ public void add(String baseEntityId, String key, String value, Long timestamp) { } } - public void batchInsertDetails(Map values, long timestamp){ + public void batchInsertDetails(Map values, long timestamp) { SQLiteDatabase database = null; + SQLiteStatement insertStatement = null; + SQLiteStatement updateStatement = null; + try { - database = masterRepository().getReadableDatabase(); + database = masterRepository().getWritableDatabase(); + + // Prepare the SQL for inserts and updates + String insertSQL = "INSERT INTO " + TABLE_NAME + " (" + + BASE_ENTITY_ID_COLUMN + ", " + KEY_COLUMN + ", " + VALUE_COLUMN + ", " + EVENT_DATE_COLUMN + + ") VALUES (?, ?, ?, ?)"; + + String updateSQL = "UPDATE " + TABLE_NAME + " SET " + VALUE_COLUMN + " = ?, " + + EVENT_DATE_COLUMN + " = ? WHERE " + BASE_ENTITY_ID_COLUMN + " = ? AND " + KEY_COLUMN + " = ?"; + + insertStatement = database.compileStatement(insertSQL); + updateStatement = database.compileStatement(updateSQL); + String baseEntityId = values.get(BASE_ENTITY_ID_COLUMN); for (String key : values.keySet()) { String val = values.get(key); + if(val == null ) continue; Boolean exists = getIdForDetailsIfExists(baseEntityId, key, val); + if (exists == null) { // Value has not changed, no need to update continue; } - ContentValues insertValues = new ContentValues(); - insertValues.put(BASE_ENTITY_ID_COLUMN, baseEntityId); - insertValues.put(KEY_COLUMN, key); - insertValues.put(VALUE_COLUMN, val); - insertValues.put(EVENT_DATE_COLUMN, timestamp); - if (exists) { - long startUpdate = System.currentTimeMillis(); - int updated = database.update(TABLE_NAME, insertValues, - BASE_ENTITY_ID_COLUMN + " = ? AND " + KEY_COLUMN + " MATCH ? ", - new String[]{baseEntityId, key}); + if (exists) { + // Bind values for update + updateStatement.bindString(1, val); // Bind VALUE_COLUMN + updateStatement.bindLong(2, timestamp); // Bind EVENT_DATE_COLUMN + updateStatement.bindString(3, baseEntityId); // Bind BASE_ENTITY_ID_COLUMN + updateStatement.bindString(4, key); // Bind KEY_COLUMN + + // Execute the update + updateStatement.execute(); + updateStatement.clearBindings(); } else { - long rowId = database.insert(TABLE_NAME, null, insertValues); + // Bind values for insert + insertStatement.bindString(1, baseEntityId); // Bind BASE_ENTITY_ID_COLUMN + insertStatement.bindString(2, key); // Bind KEY_COLUMN + insertStatement.bindString(3, val); // Bind VALUE_COLUMN + insertStatement.bindLong(4, timestamp); // Bind EVENT_DATE_COLUMN + + // Execute the insert + insertStatement.executeInsert(); + insertStatement.clearBindings(); } - } } catch (Exception e) { Timber.e(e); + } finally { + // Close the prepared statements + if (insertStatement != null) { + insertStatement.close(); + } + if (updateStatement != null) { + updateStatement.close(); + } } } + private Boolean getIdForDetailsIfExists(String baseEntityId, String key, String value) { Cursor mCursor = null; try { diff --git a/opensrp-core/src/main/java/org/smartregister/sync/ClientProcessorForJava.java b/opensrp-core/src/main/java/org/smartregister/sync/ClientProcessorForJava.java index b1e551575..2ebbcf242 100644 --- a/opensrp-core/src/main/java/org/smartregister/sync/ClientProcessorForJava.java +++ b/opensrp-core/src/main/java/org/smartregister/sync/ClientProcessorForJava.java @@ -404,9 +404,9 @@ public Boolean processCaseModel(Event event, Client client, List creates long addContent = System.currentTimeMillis(); addContentValuesToDetailsTable(contentValues, timestamp); long endAdd = System.currentTimeMillis(); - Timber.i("addContentValuesToDetailsTable took %s, ", endAdd - addContent); + Timber.i("addContentValuesToDetailsTable took, %s", endAdd - addContent); updateClientDetailsTable(event, client); - Timber.i("updateClientDetailsTable took %s, ", System.currentTimeMillis() - endAdd); + Timber.i("updateClientDetailsTable took, %s", System.currentTimeMillis() - endAdd); }