]> git.ktnx.net Git - mobile-ledger.git/commitdiff
fix SQL when cleaning obsolete transaction/accounts
authorDamyan Ivanov <dam+mobileledger@ktnx.net>
Fri, 26 Mar 2021 16:54:20 +0000 (18:54 +0200)
committerDamyan Ivanov <dam+mobileledger@ktnx.net>
Fri, 26 Mar 2021 16:54:20 +0000 (18:54 +0200)
app/src/main/java/net/ktnx/mobileledger/model/MobileLedgerProfile.java

index 6f70bda5498d283aa5d62b5ba346d34ec1806b2a..826ed397d55b74b0cc0c951add20365418082f39 100644 (file)
@@ -566,17 +566,20 @@ public final class MobileLedgerProfile {
     }
     private void deleteNotPresentAccounts(SQLiteDatabase db, int generation) {
         Logger.debug("db/benchmark", "Deleting obsolete accounts");
-        db.execSQL("DELETE FROM account_values WHERE profile=? AND generation <> ?",
+        db.execSQL("DELETE FROM account_values WHERE (select a.profile_id from accounts a where a" +
+                   ".id=account_values.account_id)=? AND generation <> ?",
                 new Object[]{id, generation});
-        db.execSQL("DELETE FROM accounts WHERE profile=? AND generation <> ?",
+        db.execSQL("DELETE FROM accounts WHERE profile_id=? AND generation <> ?",
                 new Object[]{id, generation});
         Logger.debug("db/benchmark", "Done deleting obsolete accounts");
     }
     private void deleteNotPresentTransactions(SQLiteDatabase db, int generation) {
         Logger.debug("db/benchmark", "Deleting obsolete transactions");
-        db.execSQL("DELETE FROM transaction_accounts WHERE profile=? AND generation <> ?",
+        db.execSQL(
+                "DELETE FROM transaction_accounts WHERE (select t.profile_id from transactions t " +
+                "where t.id=transaction_accounts.transaction_id)=? AND generation" + " <> ?",
                 new Object[]{id, generation});
-        db.execSQL("DELETE FROM transactions WHERE profile=? AND generation <> ?",
+        db.execSQL("DELETE FROM transactions WHERE profile_id=? AND generation <> ?",
                 new Object[]{id, generation});
         Logger.debug("db/benchmark", "Done deleting obsolete transactions");
     }