副问题[/!--empirenews.page--]
在我们开拓的应用中,一样平常城市涉及到数据库,行使数据的时辰会涉及到数据库的进级、数据的迁徙、增进行的字段等。好比,用户定制数据的生涯,文件的端点续传信息的生涯等城市涉及到数据库。
我们应用第一个版本是V1.0,在迭代版本V1.1 时,我们在数据库中增进了一个字段。因此V1.0的数据库在V1.1版本必要进级,V1.0版本进级到V1.1时原本数据库中的数据不能丢失,
那么在V1.1中就要有处所可以或许检测出来版本的差别,而且把V1.0软件的数据库进级到V1.1软件可以或许行使的数据库。也就是说,要在V1.0软件的数据库的谁人表中增进谁人字段,并赋予这个字段默认值。 应用中怎么检测数据库必要进级呢? SQLiteOpenHelper 类中有一个要领
- public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}
当我们建设工具的时辰假如传入的版本号大于之前的版本号,该要领就会被挪用,通过判定oldVersion 和 newVersion 就可以抉择怎样进级数据库。在这个函数中把老版本数据库的响应表中增进字段,并给每笔记录增进默认值即可。新版本号和老版本号城市作为onUpgrade函数的参数传进来,便于开拓者知道数据库应该从哪个版本进级到哪个版本。进级完成后,数据库会自动存储最新的版本号为当前数据库版本号。
数据库进级
SQLite提供了ALTER TABLE呼吁,应承用户重定名或添加新的字段到已有表中,可是不能从表中删除字段。而且只能在表的末端添加字段,好比,为Orders 表中添加一个字段:”ALTER TABLE Order ADDCOLUMN Country”
代码如下:
- public class OrderDBHelper extends SQLiteOpenHelper {
- private static final int DB_VERSION = 1;
- private static final String DB_NAME = "Test.db";
- public static final String TABLE_NAME = "Orders";
- public OrderDBHelper(Context context, int version) {
- super(context, DB_NAME, null, version);
- }
- @Override
- public void onCreate(SQLiteDatabase db) {
- String sql = "create table if not exists " + TABLE_NAME + " (Id integer primary key, " +
- "CustomName text, OrderPrice integer)";
- db.execSQL(sql);
- }
- @Override
- public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
- Log.e("owen", "DB onUpgrade");
- if (newVersion == 2) {
- db.execSQL("ALTER TABLE " + TABLE_NAME + " ADD COLUMN Country");
- Cursor cr = db.rawQuery("select * from " + TABLE_NAME, null);
- while (cr.moveToNext()) {
- String name = cr.getString(cr.getColumnIndex("CustomName"));
- ContentValues values = new ContentValues();
- values.put("CustomName", name);
- values.put("Country", "China");
- db.update(TABLE_NAME, values, "CustomName=?", new String[] {name});
- }
- cr.close();
- }
- }
- OrderDBHelper orderDBHelper = new OrderDBHelper(this, 2);
- SQLiteDatabase db = orderDBHelper.getWritableDatabase();
- ContentValues contentValues = new ContentValues();
- contentValues.put("OrderPrice", 100);
- contentValues.put("CustomName", "OwenChan");
- db.insert(OrderDBHelper.TABLE_NAME, null, contentValues);
- Log.e("owen", "create finish");
- Cursor cr = db.rawQuery("select * from " + OrderDBHelper.TABLE_NAME , null);
- while (cr.moveToNext()) {
- String name = cr.getString(cr.getColumnIndex("CustomName"));
- Log.e("owen", "name:" + name);
- String country = cr.getString(cr.getColumnIndex("Country"));
- Log.e("owen", "country:" + country);
- }
- cr.close();
- db.close();
数据库的迁徙
可以分一下几个步调迁徙数据库
1、 将表名改成姑且表
ALTER TABLE Order RENAME TO _Order;
(编辑:河北网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|