从 Sqlite 迁移到 Realm (Android)
Migrate from Sqlite to Realm (Android)
我现有的应用程序数据在 SQlite 上。我正在尝试将数据从 Sqlite 迁移到 Realm。我google如何迁移数据,但没有找到与此相关的任何解决方案。
我打算启动现有应用程序的更新版本。在更新应用程序时,数据必须迁移到 Realm 并且必须删除现有的 Sqlite 数据库。如果可能,请与解决方案分享一些想法。
假设您在数据库 (SqlLite) 中存储了 TODO 列表,并且您想将其迁移到领域数据库。
TODO 项的 SqlLite 接口 table
interface TodoItemModel {
String CREATE_TABLE = ""
+ "CREATE TABLE todo_list(\n"
+ " _id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,\n"
+ " name TEXT NOT NULL,\n"
+ ")";
String TABLE_NAME = "todo_item";
//columns
String _ID = "_id";
String NAME = "name";
}
待办事项的领域对象
public class TodoItem extends RealmObject {
@PrimaryKey
private Long _id;
private String name;
public TodoItem() {
}
public TodoItem(long id, String name) {
this._id = id;
this.name = name;
}
}
第 1 步。增加要扩展 SQLiteOpenHelper 的数据库的版本(即:下面给出的 DbOpenHelper class)。
第 2 步。在 DbOpenHelper class 中使用 onUpgrade 函数,您可以检查版本并将所有 SqlLite 数据记录存储到领域数据库。
final class DbOpenHelper extends SQLiteOpenHelper {
//private static final int PREVIOUS_VERSION = 1;
private static final int CURRENT_VERSION = 2;
public DbOpenHelper(Context context) {
super(context, "todo.db", null /* factory */, CURRENT_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(TodoItemModel.CREATE_TABLE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
if (oldVersion < CURRENT_VERSION) {
//get all the stored data in your db
List<TodoItem> list = select_all_items_for_list(db);
//open the realm transaction and store the list of todo's
Realm realm = Realm.getDefaultInstance();
realm.beginTransaction();
realm.insertOrUpdate(list);
realm.commitTransaction();
//finally drop table
db.execSQL("DROP TABLE IF EXISTS " + TodoItemModel.TABLE_NAME);
}
}
private List<TodoItem> select_all_items_for_list(SQLiteDatabase db) {
List<TodoItem> list = new ArrayList<>();
Cursor cursor = db.rawQuery("select * from " + TodoItemModel.TABLE_NAME, new String[0]);
if (cursor == null)
return list;
for (cursor.moveToFirst(); !cursor.isAfterLast(); cursor.moveToNext()) {
final TodoItem todoItem = new TodoItem(cursor.getLong(cursor.getColumnIndex(TodoItemModel._ID)), cursor.getString(cursor.getColumnIndex(TodoItemModel.NAME));
list.add(todoItem);
}
cursor.close();
return list;
}
}
我现有的应用程序数据在 SQlite 上。我正在尝试将数据从 Sqlite 迁移到 Realm。我google如何迁移数据,但没有找到与此相关的任何解决方案。
我打算启动现有应用程序的更新版本。在更新应用程序时,数据必须迁移到 Realm 并且必须删除现有的 Sqlite 数据库。如果可能,请与解决方案分享一些想法。
假设您在数据库 (SqlLite) 中存储了 TODO 列表,并且您想将其迁移到领域数据库。
TODO 项的 SqlLite 接口 table
interface TodoItemModel {
String CREATE_TABLE = ""
+ "CREATE TABLE todo_list(\n"
+ " _id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,\n"
+ " name TEXT NOT NULL,\n"
+ ")";
String TABLE_NAME = "todo_item";
//columns
String _ID = "_id";
String NAME = "name";
}
待办事项的领域对象
public class TodoItem extends RealmObject {
@PrimaryKey
private Long _id;
private String name;
public TodoItem() {
}
public TodoItem(long id, String name) {
this._id = id;
this.name = name;
}
}
第 1 步。增加要扩展 SQLiteOpenHelper 的数据库的版本(即:下面给出的 DbOpenHelper class)。
第 2 步。在 DbOpenHelper class 中使用 onUpgrade 函数,您可以检查版本并将所有 SqlLite 数据记录存储到领域数据库。
final class DbOpenHelper extends SQLiteOpenHelper {
//private static final int PREVIOUS_VERSION = 1;
private static final int CURRENT_VERSION = 2;
public DbOpenHelper(Context context) {
super(context, "todo.db", null /* factory */, CURRENT_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(TodoItemModel.CREATE_TABLE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
if (oldVersion < CURRENT_VERSION) {
//get all the stored data in your db
List<TodoItem> list = select_all_items_for_list(db);
//open the realm transaction and store the list of todo's
Realm realm = Realm.getDefaultInstance();
realm.beginTransaction();
realm.insertOrUpdate(list);
realm.commitTransaction();
//finally drop table
db.execSQL("DROP TABLE IF EXISTS " + TodoItemModel.TABLE_NAME);
}
}
private List<TodoItem> select_all_items_for_list(SQLiteDatabase db) {
List<TodoItem> list = new ArrayList<>();
Cursor cursor = db.rawQuery("select * from " + TodoItemModel.TABLE_NAME, new String[0]);
if (cursor == null)
return list;
for (cursor.moveToFirst(); !cursor.isAfterLast(); cursor.moveToNext()) {
final TodoItem todoItem = new TodoItem(cursor.getLong(cursor.getColumnIndex(TodoItemModel._ID)), cursor.getString(cursor.getColumnIndex(TodoItemModel.NAME));
list.add(todoItem);
}
cursor.close();
return list;
}
}