]> git.ktnx.net Git - mobile-ledger.git/blob - app/src/main/java/net/ktnx/mobileledger/dao/AccountValueDAO.java
methods for deleting all DB tables
[mobile-ledger.git] / app / src / main / java / net / ktnx / mobileledger / dao / AccountValueDAO.java
1 /*
2  * Copyright © 2021 Damyan Ivanov.
3  * This file is part of MoLe.
4  * MoLe is free software: you can distribute it and/or modify it
5  * under the term of the GNU General Public License as published by
6  * the Free Software Foundation, either version 3 of the License, or
7  * (at your opinion), any later version.
8  *
9  * MoLe is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  * GNU General Public License terms for details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with MoLe. If not, see <https://www.gnu.org/licenses/>.
16  */
17
18 package net.ktnx.mobileledger.dao;
19
20 import androidx.annotation.NonNull;
21 import androidx.lifecycle.LiveData;
22 import androidx.room.Dao;
23 import androidx.room.Delete;
24 import androidx.room.Insert;
25 import androidx.room.OnConflictStrategy;
26 import androidx.room.Query;
27 import androidx.room.Update;
28
29 import net.ktnx.mobileledger.db.AccountValue;
30
31 import java.util.List;
32
33 @Dao
34 public abstract class AccountValueDAO extends BaseDAO<AccountValue> {
35     @Insert(onConflict = OnConflictStrategy.REPLACE)
36     public abstract long insertSync(AccountValue item);
37
38     @Update
39     public abstract void updateSync(AccountValue item);
40
41     @Delete
42     public abstract void deleteSync(AccountValue item);
43
44     @Query("DELETE FROM account_values")
45     public abstract void deleteAllSync();
46
47     @Query("SELECT * FROM account_values WHERE account_id=:accountId")
48     public abstract LiveData<List<AccountValue>> getAll(long accountId);
49
50     @Query("SELECT * FROM account_values WHERE account_id = :accountId AND currency = :currency")
51     public abstract AccountValue getByCurrencySync(long accountId, @NonNull String currency);
52 }