Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/sqlite/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
android room ORM具有初始值_Android_Sqlite_Android Room - Fatal编程技术网

android room ORM具有初始值

android room ORM具有初始值,android,sqlite,android-room,Android,Sqlite,Android Room,在Android ORM中,我如何在SQLite的表中添加一些初始值?我通常在创建SQLite时这样做。 但在room上,我如何才能做到这一点,这意味着在数据库上创建后添加了一些初始值。 谢谢您的回答。您可以使用最新版本的Room library中提供的RoomDatabase.Callback来完成此操作 您需要实现RoomDatabase.Callback的onCreate和onOpen方法,并将其添加到RoomDatabase.Builder中,如下所示 RoomDatabase.Call

在Android ORM中,我如何在SQLite的表中添加一些初始值?我通常在创建SQLite时这样做。 但在room上,我如何才能做到这一点,这意味着在数据库上创建后添加了一些初始值。
谢谢您的回答。

您可以使用最新版本的Room library中提供的RoomDatabase.Callback来完成此操作

您需要实现RoomDatabase.Callback的onCreate和onOpen方法,并将其添加到RoomDatabase.Builder中,如下所示

RoomDatabase.Callback

  RoomDatabase.Callback rdc = new RoomDatabase.Callback(){
        public void onCreate (SupportSQLiteDatabase db){
        // do something after database has been created
        }
        public void onOpen (SupportSQLiteDatabase db){
        //do something every time database is open
        }
    };
将回调添加到房间数据库生成器中

 yourDatabase = Room.databaseBuilder(context,
                            YourDatabase.class, "your db").addCallback(rdc).build();

参考资料:

如何//在创建数据库后做一些事情,在您看来应该是这样的。如果我们使用db.insert(…),当我们通过DAOs访问它时,我们将失去文件室提供的类型安全性。若我们让数据库实例获取DAO并通过它插入,则会触发onCreate()的递归调用。有第三种解决方案吗?