房间 - 插入行时出错

时间:2017-10-27 11:58:43

标签: android android-room

这是我使用Room Persistence Library将数据插入数据库的方法:

@Entity(tableName = "users")
public class ExpParent implements Parent<ExpChild>, Serializable {
@Ignore
private List<ExpChild> mChildrenList;

@Embedded
@SerializedName("UserInfo")
private ExpChild childrenList;

private String UserName;
private String CreationDateTime;
@PrimaryKey(autoGenerate = false)
@NonNull
private String Id ="";
private String Topic;
//......

数据访问对象:

@Dao
public interface UserDao {

@Query("SELECT * FROM users")
List<ExpParent> getAllUsers();

@Insert(onConflict = IGNORE)
Long[] insertAllUsers(List<ExpParent> expParents);
}

但是当我想在我的数据库中显示插入对象的数量时,我收到了这个错误:

 FATAL EXCEPTION: main
                                             Process: com.example.sayres.a2_expandrecyandretrofit, PID: 2830
                                             android.content.res.Resources$NotFoundException: String resource ID #0x8
                                                 at android.content.res.Resources.getText(Resources.java:312)
                                                 at android.widget.Toast.makeText(Toast.java:286)
                                                 at com.example.sayres.a2_expandrecyandretrofit.MainActivity$2$1$1.run(MainActivity.java:72)
                                                 at android.os.Handler.handleCallback(Handler.java:739)
                                                 at android.os.Handler.dispatchMessage(Handler.java:95)
                                                 at android.os.Looper.loop(Looper.java:148)
                                                 at android.app.ActivityThread.main(ActivityThread.java:5417)
                                                 at java.lang.reflect.Method.invoke(Native Method)
                                                 at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
                                                 at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

这是我将对象插入db:

的方法
           public void onResponse(Call<ServerResponse> call, Response<ServerResponse> response) {
            ServerResponse body = response.body();
            final List<ExpParent> users = body.getUsers();
            new Thread(new Runnable() {
                @Override
                public void run() {
                    final Long[] longs = db.userDao().insertAllUsers(users);

                    MainActivity.this.runOnUiThread(new Runnable() {
                        @Override
                        public void run() {
                            Toast.makeText(MainActivity.this, longs.length, Toast.LENGTH_SHORT).show();
                        }
                    });

                }
            }).start();

我是通过改造,从我的服务中获取数据作为列表然后进入工作线程我已将这些数据插入到我的db.finally我想显示如何将数字行插入到我的数据库中。但是我得到了错误! 我的错是什么?

1 个答案:

答案 0 :(得分:4)

您滥用Toast.makeText() 第二个参数可以是int资源ID(示例R.string.some_string),也可以是String
您正在尝试传递一个不是资源ID的整数(longs.length)。要显示整数,您必须先将其转换为字符串。

为此,您可以为其添加一个空字符串:

Toast.makeText(MainActivity.this, longs.length + "", Toast.LENGTH_SHORT).show();