如何通过 Viewmodel 调用 sqlite 方法?
Posted
技术标签:
【中文标题】如何通过 Viewmodel 调用 sqlite 方法?【英文标题】:How do i call sqlite methods through Viewmodel? 【发布时间】:2021-10-27 03:34:45 【问题描述】:我到处搜索,但没有找到任何关于使用 MVVM 的 sqlite 的信息或教程或博客。如何为我的 sqlite 方法创建视图模型?我尝试了各种方法来访问它,但给了我错误
以下是我的 sqlite 助手类代码
public class DbHelper extends SQLiteOpenHelper
private static final int DATABASE_VERSION = 2;
static final String DATABASE_NAME = "kuncorosqlite.db";
public static final String TABLE_SQLite = "sqlite";
public static final String COLUMN_ID = "id";
public static final String COLUMN_NAME = "name";
public static final String COLUMN_ADDRESS = "address";
public DbHelper(Context context)
super(context, DATABASE_NAME, null, DATABASE_VERSION);
@Override
public void onCreate(SQLiteDatabase db)
final String SQL_CREATE_MOVIE_TABLE = "CREATE TABLE " + TABLE_SQLite + " (" +
COLUMN_ID + " INTEGER PRIMARY KEY autoincrement, " +
COLUMN_NAME + " TEXT NOT NULL, " +
COLUMN_ADDRESS + " TEXT NOT NULL" +
" )";
db.execSQL(SQL_CREATE_MOVIE_TABLE);
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
db.execSQL("DROP TABLE IF EXISTS " + TABLE_SQLite);
onCreate(db);
public ArrayList<HashMap<String, String>> getAllData()
ArrayList<HashMap<String, String>> wordList;
wordList = new ArrayList<HashMap<String, String>>();
String selectQuery = "SELECT * FROM " + TABLE_SQLite;
SQLiteDatabase database = this.getWritableDatabase();
Cursor cursor = database.rawQuery(selectQuery, null);
if (cursor.moveToFirst())
do
HashMap<String, String> map = new HashMap<String, String>();
map.put(COLUMN_ID, cursor.getString(0));
map.put(COLUMN_NAME, cursor.getString(1));
map.put(COLUMN_ADDRESS, cursor.getString(2));
wordList.add(map);
while (cursor.moveToNext());
Log.e("select sqlite ", "" + wordList);
database.close();
return wordList;
public void insert(String name, String address)
SQLiteDatabase database = this.getWritableDatabase();
String queryValues = "INSERT INTO " + TABLE_SQLite + " (name, address) " +
"VALUES ('" + name + "', '" + address + "')";
Log.e("insert sqlite ", "" + queryValues);
database.execSQL(queryValues);
database.close();
public void update(int id, String name, String address)
SQLiteDatabase database = this.getWritableDatabase();
String updateQuery = "UPDATE " + TABLE_SQLite + " SET "
+ COLUMN_NAME + "='" + name + "', "
+ COLUMN_ADDRESS + "='" + address + "'"
+ " WHERE " + COLUMN_ID + "=" + "'" + id + "'";
Log.e("update sqlite ", updateQuery);
database.execSQL(updateQuery);
database.close();
public void delete(int id)
SQLiteDatabase database = this.getWritableDatabase();
String updateQuery = "DELETE FROM " + TABLE_SQLite + " WHERE " + COLUMN_ID + "=" + "'" + id + "'";
Log.e("update sqlite ", updateQuery);
database.execSQL(updateQuery);
database.close();
到目前为止,我已经尝试过的视图模型:-
public class Viewmodell extends androidViewModel
private DbHelper repository ;
MutableLiveData<ArrayList<HashMap<String, String>>> allNotesLivedata;
public Viewmodell(@NonNull Application application)
super(application);
repository = new DbHelper(application);
allNotesLivedata = repository.getAllData();
void insert(String name,String Address)
repository.insert(name,Address);
void update(int id, String name, String address)
repository.update(id,name,address);
void delete(int id)
repository.delete(id);
public LiveData<ArrayList<HashMap<String, String>>> getAllNotes()
return allNotesLivedata;
请不要建议我使用room
,因为这不是我的要求
【问题讨论】:
您可以在视图模型中创建DbHelper
类的新对象并访问这些方法。你试过这样吗?
你能粘贴你的ViewModel
代码吗?
我添加了@Jacek & jeel
@JeelVankhede 我被困在如何访问它...根据我的 sqlite 类
allNotes = repository.getAllData();
出现错误
【参考方案1】:
错误只是表示您没有提交兼容的值:
在您的代码中,在创建 MutableLiveData 时,您已经分配了它
ArrayList<HashMap<String,String>>
但是在为 MutableLiveData 设置值时,您只是传递了一个 HashMap 。因此,您需要做的不是直接传递 HashMap,而是需要创建一个 ArrayList,然后向该 arrayList 传递您的 HashMap,然后将 ArrayList 设置为 MutableLiveData。
你可以这样做。下面的代码是为了说明目的
//Create an arrayList
ArrayList<HashMap> listofMaps = new ArrayList();
//then add all your hashmaps to your list
listofMaps.add(map);
//and then set it to the MutableLiveData
wordList.postValue(listOfMaps);
或者代替上面的过程,解决这个问题的第二种方法是,你只需要创建类型的MutableLiveData:HashMap
wordList = new MutableLiveData<HashMap<String,String>>();
【讨论】:
karunesh 我添加了最新的 ss 请看一下 但是我在获取列表时遇到了一个问题,你能帮忙吗?我可以更新代码吗? 您需要为同一个问题创建另一个问题。更新代码并将其带到另一个上下文只会损害您所询问的目的,并且没有其他人可以从中受益。请记住,我们都在这里互相帮助 只需在评论部分ping下一个问题链接让我知道,然后用你之前发布的那些ss恢复这篇文章以上是关于如何通过 Viewmodel 调用 sqlite 方法?的主要内容,如果未能解决你的问题,请参考以下文章
如何在 ViewModel 类中调用 TranslateTo?
是否可以通过在 Xaml 中调用来自 ViewModel 的命令的方式来处理 Storyboard.Completed 事件
如何使用 ViewModel 和 LiveData 进行改造 API 调用