Android context provider DB更新

2024-05-28 06:38

本文主要是介绍Android context provider DB更新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

實際測試
new MyDBHlper時,會自動判斷,帶入的 version是不是跟之前的一樣,如果不一樣,就會先執行 MyDBHlper的onUpgrade

執行順序為

MyContentProvider: onCreate: 
MyDBHlper: onUpgrade: oldVersion:1newVersion:2
MyDBHlper: onCreate:

复制代码
public class MyContentProvider extends ContentProvider {@Overridepublic boolean onCreate() {Log.d(Tag, "onCreate: ");// MyDBHlper dbHper = new MyDBHlper(getContext(), DBname, null, 1);//FIXME:test version changeMyDBHlper dbHper = new MyDBHlper(getContext(), DBname, null, 2);MyDB = dbHper.getWritableDatabase();return true;}
}public class MyDBHlper extends SQLiteOpenHelper {@Overridepublic void onCreate(SQLiteDatabase db) {Log.d(Tag, "onCreate: ");db.execSQL(crTBsql);db.execSQL(initDBDate);}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {Log.d(Tag, "onUpgrade: oldVersion:" + oldVersion + "newVersion:" + newVersion);db.execSQL("DROP TABLE IF EXISTS " + TBname);onCreate(db);}
}
复制代码

 

***************************************************************************************************

 

轉載自http://mrraybox.blogspot.tw/2017/01/android-sqlite-onupgrade.html

 

本篇主要是示範:
1. 說明onUpgrade何時會啟用。
2. 示範如何使用onUpgrade。
3. 觀察onUpgrade使用後的前後差異。

相信開始接觸SQLite的大家都知道SQLiteOpenHelper中有一個方法叫onUpgrade,但是這個方法是做什麼用的呢?首先我們知道onCreate是在Android載入時,找不到對應的資料庫資料,就會觸發的一個方法。而onUpgrade呢,則是在資料庫的結構有所改變時,才會觸發的一個方法。

舉例來說,假如我在一月時,寫了一個App給其他人使用,在二月時,因改版需求,所以需要新增或刪減資料表的欄位。但是此時,那些使用我們所寫的App的用戶們,在這段期間已經儲存許多資料了。為了保存用戶舊的資料,此時我們就需要運用到onUpgrade來修改我們資料表的結構。

首先這裡示範我們一開始所寫的App。首先Layout部分的配置。
File Name:activity_main.xml

复制代码
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent" ><LinearLayoutandroid:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical" ><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="horizontal" ><Buttonandroid:id="@+id/btn_new"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="新增" /><Buttonandroid:id="@+id/btn_delete"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="刪除" /></LinearLayout><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"android:gravity="right"android:orientation="horizontal" ><EditTextandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:hint="ID"android:id="@+id/edt1"android:layout_weight="1" /><EditTextandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:hint="Row1"android:id="@+id/edt2"android:layout_weight="1" /><EditTextandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:hint="Row2"android:id="@+id/edt3"android:layout_weight="1" /><Buttonandroid:id="@+id/btn_alter"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="修改" /></LinearLayout><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:text="txt"android:id="@+id/txt"/></LinearLayout></ScrollView>
复制代码

File Name:MainActivity

复制代码
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;public class MainActivity extends AppCompatActivity implements View.OnClickListener {private Button btnNew, btnDel, btnAlt;private EditText edtID, edtRow1, edtRow2;private TextView txt;private MyHelper helper;private SQLiteDatabase db;private Cursor c;private String result;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);btnNew = (Button) this.findViewById(R.id.btn_new);btnDel = (Button) this.findViewById(R.id.btn_delete); btnAlt = (Button) this.findViewById(R.id.btn_alter);edtID = (EditText) this.findViewById(R.id.edt1);edtRow1 = (EditText) this.findViewById(R.id.edt2);edtRow2 = (EditText) this.findViewById(R.id.edt3);txt = (TextView) this.findViewById(R.id.txt);btnNew.setOnClickListener(this);btnDel.setOnClickListener(this);btnAlt.setOnClickListener(this);helper = new MyHelper(this, "dbname", null, 1);db = helper.getWritableDatabase();queryDB();}private void queryDB() {c = db.query("tablename", null, null, null, null, null, null);result="";for(int i=0; i<c.getColumnCount();i++){result+=c.getColumnName(i)+", ";}result+="\n";while (c.moveToNext()) {result += c.getString(c.getColumnIndex("_id")) + ", "+c.getString(c.getColumnIndex("row1")) + ", "+c.getString(c.getColumnIndex("row2")) +"\n";}txt.setText(result);}@Overridepublic void onClick(View view) {String id = edtID.getText().toString();ContentValues values = new ContentValues();switch (view.getId()){case R.id.btn_new:values.put("row1", "Row1");values.put("row2", "Row2");db.insert("tablename", null, values);queryDB();break;case R.id.btn_delete:db.delete("tablename", "_id="+id,null);queryDB();break;case R.id.btn_alter:String row1 = edtRow1.getText().toString();String row2 = edtRow2.getText().toString();values.put("row1", row1);values.put("row2", row2);db.update("tablename", values, "_id=" + id, null);queryDB();break;}}@Overridepublic void finish() {c.close();db.close();super.finish();}
}    
复制代码

File Name:MyHelper

复制代码
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;public class MyHelper extends SQLiteOpenHelper {private String createTab;private String tableName = "tablename";public MyHelper(Context context, String db_name, SQLiteDatabase.CursorFactory factory, int db_version) {super(context, db_name, factory, db_version);}@Overridepublic void onCreate(SQLiteDatabase db) {createTab = "create table "+ tableName +" (_id integer primary key AUTOINCREMENT, row1 text, row2 text)";db.execSQL(createTab);}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {}
}
复制代码

在用戶新增完資料後,就會變成下面這樣。

接著是我們改版後的程式碼。 
File Name:MainActivity
复制代码
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;public class MainActivity extends AppCompatActivity implements View.OnClickListener {private Button btnNew, btnDel, btnAlt;private EditText edtID, edtRow1, edtRow2;private TextView txt;private MyHelper helper;private SQLiteDatabase db;private Cursor c;private String result;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);btnNew = (Button) this.findViewById(R.id.btn_new);btnDel = (Button) this.findViewById(R.id.btn_delete);btnAlt = (Button) this.findViewById(R.id.btn_alter);edtID = (EditText) this.findViewById(R.id.edt1);edtRow1 = (EditText) this.findViewById(R.id.edt2);edtRow2 = (EditText) this.findViewById(R.id.edt3);txt = (TextView) this.findViewById(R.id.txt);btnNew.setOnClickListener(this);btnDel.setOnClickListener(this);btnAlt.setOnClickListener(this);helper = new MyHelper(this, "dbname", null, 2);db = helper.getWritableDatabase();queryDB();}private void queryDB() {c = db.query("tablename", null, null, null, null, null, null);result="";for(int i=0; i<c.getColumnCount();i++){result+=c.getColumnName(i)+", ";}result+="\n";while (c.moveToNext()) {result += c.getString(c.getColumnIndex("_id")) + ", "+c.getString(c.getColumnIndex("row1")) + ", "+c.getString(c.getColumnIndex("row2")) +"\n";}txt.setText(result);}@Overridepublic void onClick(View view) {String id = edtID.getText().toString();ContentValues values = new ContentValues();switch (view.getId()){case R.id.btn_new:values.put("row1", "Row1");values.put("row2", "Row2");db.insert("tablename", null, values);queryDB();break;case R.id.btn_delete:db.delete("tablename", "_id="+id,null);queryDB();break;case R.id.btn_alter:String row1 = edtRow1.getText().toString();String row2 = edtRow2.getText().toString();values.put("row1", row1);values.put("row2", row2);db.update("tablename", values, "_id=" + id, null);queryDB();break;}}@Overridepublic void finish() {c.close();db.close();super.finish();}
}
复制代码

File Name:MyHelper

复制代码
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;public class MyHelper extends SQLiteOpenHelper {private String createTab;private String tableName = "tablename";public MyHelper(Context context, String db_name, SQLiteDatabase.CursorFactory factory, int db_version) {super(context, db_name, factory, db_version);}@Overridepublic void onCreate(SQLiteDatabase db) {   createTab = "create table "+ tableName +" (_id integer primary key AUTOINCREMENT, row1 text, row2 text, row3 text)";db.execSQL(createTab);}@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {if(oldVersion == 1 && newVersion == 2){//Adding a row3String sql = "alter table "+ tableName +" add row3 text";db.execSQL(sql);}}
}
复制代码

實作後,則會變成下面這樣。有發現差異在哪嗎?


改版後的App不但保存了用戶的舊資料,同時還新增了一個row3的欄位,是不是很方便的一個功能呀!

这篇关于Android context provider DB更新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1009817

相关文章

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

hdu1689(线段树成段更新)

两种操作:1、set区间[a,b]上数字为v;2、查询[ 1 , n ]上的sum 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdl

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影