我正在尝试从后台服务中的Android Room数据库中读取数据。没有异常,但没有返回任何数据。
我编写了一个函数来选择DAO中表中的所有行。从后台服务调用该函数成功,但它不返回任何数据。
我的" contact“类保存联系信息(姓名、电话号码、电子邮件)并定义数据库模式。数据库保存联系人的行,以姓名、电话号码、电子邮件为列。
在DAO中返回LiveData的函数是:
@Query("SELECT * FROM contacts_table")
LiveData<List<Contact>> getAll();
其中"contacts_table“是保存联系人信息的数据库表。
我按如下方式调用了getAll:
AppDatabase db = AppDatabase.getDatabase(messageSenderContext.getApplicationContext());
mContactDAO = db.contactDAO();
mAllContacts = mContactDAO.getAll();
其中mContactDao是ContactDAO (我的Contact类的数据库访问对象),mAllContacts是LiveData>。这些是调用getAll()的类的私有字段。
与mContactDAO.getAll()一样,db.contactDAO()返回一个对象。但是尝试使用mAllContacts.getValue()从mAllContacts解压列表将返回null。
发布于 2018-06-22 09:00:22
事实证明这是对LiveData的滥用。这需要一个观察者来实际获取数据。
https://stackoverflow.com/questions/50975996
复制相似问题