- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
主要 Activity
myRoomDatabase3 = Room.databaseBuilder(getApplicationContext(),MyRoomDatabase.class,"messagedb3").fallbackToDestructiveMigration().allowMainThreadQueries().build();
Message message4 = new Message();
message4.setTime("14:10");
message4.setContactName("Deepika");
message4.setDate("02-12-2018");
message4.setMsg("HI");
MainActivity.myRoomDatabase3.myDao().addMessage(message4);
Toast.makeText(MainActivity.this,"Message added",Toast.LENGTH_SHORT).show();
MyDao接口(interface)代码:-
import android.arch.persistence.room.Dao;
import android.arch.persistence.room.Insert;
import android.arch.persistence.room.Query;
@Dao
public interface MyDao {
@Insert
public void addMessage(Message message);
@Query("SELECT * FROM messages3 WHERE message_date LIKE :givenDate AND " + "message_time LIKE :givenTime LIMIT 1")
public Message getMessageInfo(String givenDate,String givenTime);
我的消息类:-
import android.arch.persistence.room.ColumnInfo;
import android.arch.persistence.room.Entity;
import android.arch.persistence.room.PrimaryKey;
@Entity(tableName = "messages3")
public class Message {
@PrimaryKey(autoGenerate = true)
private int id;
@ColumnInfo(name = "message_date")
private String date;
@ColumnInfo(name = "message_time")
private String time;
@ColumnInfo(name = "message_contactName")
private String contactName;
@ColumnInfo(name = "message_msg")
private String msg;
public String getDate() {
return date;
}
public void setDate(String date) {
this.date = date;
}
public String getTime() {
return time;
}
public void setTime(String time) {
this.time = time;
}
public String getContactName() {
return contactName;
}
public void setContactName(String contactName) {
this.contactName = contactName;
}
public String getMsg() {
return msg;
}
public void setMsg(String msg) {
this.msg= msg;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
尝试从给定日期和时间的数据库的一行中检索数据:-
Calendar calender = Calendar.getInstance();
calender.set(Calendar.YEAR,2018);
calender.set(Calendar.MONTH, 11);
calender.set(Calendar.DAY_OF_MONTH, 02);
SimpleDateFormat simpledateformat = new SimpleDateFormat("dd-MM-yyyy");
String Date = simpledateformat.format(calender.getTime());
Calendar cal = Calendar.getInstance();
cal.set(Calendar.HOUR_OF_DAY, 14);
cal.set(Calendar.MINUTE, 10);
cal.set(Calendar.SECOND,00);
SimpleDateFormat simpletimeformat = new SimpleDateFormat("hh:mm");
String Time = simpletimeformat.format(cal.getTime());
Message message = MainActivity.myRoomDatabase3.myDao().getMessageInfo(Date,Time);
String contactName = (message==null) ? "No data found" : message.getContactName();
String text = (message == null) ? "No data found" : message.getMsg();
我的房间数据库类:-
import android.arch.persistence.room.Database;
import android.arch.persistence.room.RoomDatabase;
@Database(entities = {Message.class},version = 12,exportSchema = false)
public abstract class MyRoomDatabase extends RoomDatabase {
public abstract MyDao myDao();
}
我的 build.gradle 文件:-
allprojects {
repositories {
google()
jcenter()
}
依赖关系-
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'com.android.support:appcompat-v7:28.0.0'
implementation 'com.android.support:appcompat-v7:28.0.0-rc02'
implementation 'com.android.support.constraint:constraint-layout:1.1.3'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.2'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
implementation 'android.arch.persistence.room:runtime:1.0.0'
annotationProcessor 'android.arch.persistence.room:compiler:1.0.0'
}
如何消除错误?哪里出了问题?如何从日期和时间字段中搜索读取单行数据?
我已经添加了我正在使用的整个代码。请告诉我哪里出了问题。我在这上面停留了 2-3 天。一定是出了什么问题。这是什么?为什么查询返回空值?
最佳答案
您的查询未返回任何内容。所以消息为空。您需要确保您的查询返回某些内容或更好的结果,添加代码来处理未找到任何内容的情况,因为这似乎是一种合理的可能状态。
调试器可以比 SO 更快地给出相同的答案。
这将避免 NullPointerException:
String text = (message == null) ? “No data found.” : message.getMsg();
关于java - 无法通过选择检索房间数据库中单行的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53540729/
我在使用 Room 或 idk 时遇到问题,实际上问题出在哪里,我需要帮助找出问题出在哪里,我正在使用 Hilt DI,创建数据库实例的那一刻它崩溃了这是我的代码 错误 E/AndroidRuntim
我有一个关于数据结构和类设计的问题(抱歉太长了)。为了简单起见,假设这是一个游戏,我想在房间之间导航(想象一系列 2D 非滚动屏幕,例如早期的银河战士/恶魔城)。每个房间可以有许多导出(例如上、下、左
我使用当前日期(1-25)作为父ID并使用房间(08-00_11-00_karpet1-)作为 child ID。该数据库中包含在该日期(父 ID)订购该房间(子 id)的用户信息。 问题1 使用此布
在我的 Android 项目中,我使用 Room 库来处理 SQLite 数据库。我使用我的数据库来保存国家电话代码。我的数据库预装了两个国家(观看 populateDatabaseWithCount
我正在尝试将 Room 持久性库添加到 Android 应用程序项目中。在 build.gradle 文件中,我添加了以下依赖项: implementation 'android.arch.persi
人们可以提前从 25 场讲座中选择最多 5 场。所有这些讲座都在五个房间的五个时间段内在一天内进行。听众可以参加的每个(首选)讲座都让她更快乐,他选择但不能参加的每个讲座(因为另一个首选讲座在同一时间
我在 Android 上使用 OrmLite 而不是 SQLite 和 SQLCipher 来加密数据库。有没有办法加密 Room 数据库? 最佳答案 默认情况下,Room 将数据存储在应用程序的内部
使用 Room ORM,我使用 @Entity 注释声明了一个实体 EQPreset。该实体包含一个数组 int[]。它给出以下错误: 错误:无法确定如何将此字段 (int[] arr) 保存到数据库
我正在尝试构建一个管理 child 托儿所的应用程序,特别是管理哪个 child 在哪个时间点在托儿所的哪个房间里。 Nursery 链式店有多个分支机构。每个分店有几个房间,每个房间对应一个年龄段,
我在生产环境中遇到了“android.database.sqlite.SQLiteDatabaseLockedException”异常。错误分析时出现异常。我的项目数据库有空间。项目中没有使用多进程。
我想实现 Android Room 持久性。 这是我的 DAO 界面。 @Dao interface FoodDao { /** * Returns all data in tabl
我正在尝试使用 Room 数据库和 LiveData。我有 ViewModels,它保存从 dao 获得的 LiveData。如果我更新Transaction ,然后LiveData>观察正常,但是
在 Firebase ,创建“房间”(例如用于聊天)很容易,正如其各种示例中所记录的那样。 对于聊天的数据结构,我会使用这样的东西: rooms room1 member_co
我试图从 Activity 中将一行插入 SQLITE 数据库,然后返回要存储在 Activity 中的变量中的 rowId。请参阅下面我使用的方法和逻辑。 private void insert
我正在使用 XMPPFramework 开发聊天应用程序 加入现有房间后如何接收消息历史记录? 现在我像这样加入房间: XMPPJID *roomJid = [XMPPJID jidWithStrin
我在我的应用程序中使用 Room 并将数据插入到我的数据库中时 ConcurrentModificationException有时会被抛出。为什么会这样? 我使用分页 api,在每次 api 调用后,
我想为 pb 添加值,由于将 pb_value 包含到实体中,应用程序崩溃了。我是学习室的新手,我不确定将额外项目合并到数据库中的正确方法。 E/AndroidRuntime: FATAL EXCEP
我想在当前 pb 中添加值、日期和详细信息。我在 pbInfo 的数据库中收到错误“冲突声明”。我应该如何修复此错误? @Entity(tableName = "pb_table") data cla
我正在尝试制作一个聊天应用程序,用户可以在其中聊天。我想将两个用户 uid 字符串插入函数并返回一个连接的字符串。但我希望以某种方式组织 uid,以便返回的值始终相同。 func (id1, id2)
我不断收到以下错误: Cannot figure out how to save this field into database. You can consider adding a type co
我是一名优秀的程序员,十分优秀!