Android数据库使用指南(下)
前言
上面已经说了,对表进行修改,其实就是对数据库进行升级,删除表也算升级啊,反正就是发生变化,数据库就需要升级。
所以老实说其实有个地方决定了数据库的版本
public class DBHelper extends SQLiteOpenHelper {
public static final String db_name = "test.db";
public DBHelper(Context context, int version) {
super(context, db_name, null, version);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table table1 (" +
" _byte byte," +
" _long long," +
" _text text," +
" _short short," +
" _int int," +
" _float float," +
" _double double," +
" _boolean boolean," +
" _blob blob" +
")");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
看看这个构造方法,其中第二个参数就是数据库版本号,你可以在第一次发布应用的时候,这个版本号填写1,然后下一个版本,版本号填写2,但是数据库升级可没有那么简单的单纯改个数字就升级完毕了。
是时候好好的介绍一下onCreate和onUpgrade方法了。
onCreate:在创建数据库的时候,调用该方法,如果数据库已经存在了,这个方法将不会被调用。
onUpgrade:当构造方法中的那个version,也就是数据库版本升高了的时候,这个方法才会被调用。
比如,第一次发布应用的时候,这里的version是1,第二次发布应用的时候,刚好数据库要新建一个表,然后需要升级一下数据库,这里于是就传递了个2,这时候onUpgrade方法就会被调用了,不过onCreate方法可不会被调用了啊,因为数据库已经存在了。
这里有一点要提一下,数据库只能升级,不能降级,不然会报错的。
创建数据库
上面大概说了,onCreate和onUpgrade方法大概是在什么时候被调用的,所以基于这个原理。如果我们要新增表或者修改表,我们就在onUpgrade方法中写。这里举个例子,假设我们已经发布了数据库版本为1的应用。
数据库建立如下:
public class DBHelper extends SQLiteOpenHelper {
public static final String db_name = "test.db";
public DBHelper(Context context, int version) {
super(context, db_name, null, version);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table table1 (_text text)");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
此时我们调用的方式为:
// 当前数据库的版本为1
new DBHelper(context, )
其实我们就创建了一个表名为table1的表而已,不妨运行后来看看,数据库文件保存在data/data/包名/databases/xxx.db
表也创建好了
看看表中字段
都没有问题,接下来,我们开始升级数据库,比如,新建表。
数据库升级-新增表
接下来,我们新增一个表,所以就应该这样写:
public class DBHelper extends SQLiteOpenHelper {
public static final String db_name = "test.db";
public DBHelper(Context context, int version) {
super(context, db_name, null, version);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table table1 (_text text)");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
switch (newVersion) {
case :
case :
// 新增表table2
db.execSQL("create table table2 (_text text)");
break;
}
}
}
所以在用的时候,就应该这样用:
// 当前数据库的版本为2
new DBHelper(context, )
看看?
没啥问题
数据库升级-删除表
其实主要还是调用SQL语句执行任务,所以:
public class DBHelper extends SQLiteOpenHelper {
public static final String db_name = "test.db";
public DBHelper(Context context, int version) {
super(context, db_name, null, version);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table table1 (_text text)");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
switch (newVersion) {
case :
case :
db.execSQL("create table table2 (_text text)");
case :
db.execSQL("drop table table2");
break;
}
}
}
使用:
// 当前数据库的版本为3
new DBHelper(context, )
数据库升级-新增字段
给某个表新增字段:
public class DBHelper extends SQLiteOpenHelper {
public static final String db_name = "test.db";
public DBHelper(Context context, int version) {
super(context, db_name, null, version);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("create table table1 (_text text)");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
switch (newVersion) {
case :
case :
db.execSQL("create table table2 (_text text)");
case :
db.execSQL("drop table table2");
case :
db.execSQL("alter table table1 ADD _long long");
break;
}
}
}
使用:
// 当前数据库的版本为4
new DBHelper(context, )
总结
大概差不多就是以这种方式对数据库进行升级,这里主要是使用sql语句对数据库进行操作,如果对sql语句不熟悉的人,可能需要在使用前查询一下了。
这里大概说几种常用的sql语句的结构:
新增表:
create table 表名 (字段 类型)
删除表:
drop table 表名
修改表-新增表字段
alter table 表名 add 字段 类型
修改表-删除字段
alter table 表名 drop column 字段名
SQLite支持正常的SQL语句,只需要调用SQLiteDatabase对象的execSQL方法就可以直接通过SQL语句对数据库进行操作了
大家可以在这里了解到SQL语句的用法
还有一点要说明的就是,为啥onUpgrade方法中的switch,不是每个case都对应一个break,这里其实是一个小技巧,我们在使用数据库升级的时候,往往switch这里是这样写的:
switch (newVersion) {
case :
// 更新1
case :
// 更新2
case :
// 更新3
case :
// 更新4
case :
// 更新5
case :
// 更新6
case :
// 更新7
...
break;
}
因为这样写有一个好处,假设我们的应用,最新版已经升级到第7个版本了,但是有的用户还在用第4个版本,这时候,如果这个用户直接升级到最新的第7版,这里的执行,就会是
更新5
更新6
更新7
就把以前遗漏的更新全部赶上了,这就这样写的好处。
本章主要就是讲数据库升级,流程大概就是这么个流程,就这样吧!
---------------------
版权声明:本文为CSDN博主「你缺少想象力」的原创文章,遵循CC 4.0 by-sa版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/IT_XF/article/details/82684562
Android数据库使用指南(下)的更多相关文章
- Android数据库使用指南(上)
前言Android上的数据库是sqlite,虽然这个数据库是轻量级的,但是储存的东西可不少,sqlite官方表示理论存储容量为140TB,目前应该没有那么大容量的手机,存储能力太强了. 关于如何使用S ...
- Android数据库
Android数据库 什么情况下我们才用数据库做数据存储? 大量数据结构相同的数据需要存储时.Android内置了sqlite,轻量级. 创建数据库的方法 创建一个类继承SqliteOpenHelpe ...
- Android Realm数据库使用指南
Android Realm数据库使用指南 Realm数据库, 目前有Java, Objective‑C, React Native, Swift, Xamarin的几种实现, 是一套用来取代SQLit ...
- 不root手机的情况下查看Android数据库
最近写Android的时候发现想要读取数据库很不方便,使用adb工具的方法需要root手机,而华为手机root十分麻烦,需要解除密码,一些品牌手机即使root了也没有sqlite3命令,总之十分麻烦. ...
- 读书笔记--Android Gradle权威指南(下)
前言 最近看了一本书<Android Gradle 权威指南>,收获挺多,就想着来记录一些读书笔记,方便后续查阅. 本篇内容是基于上一篇:读书笔记--Android Gradle权威指南( ...
- Unity开发Android应用优化指南(下)
http://forum.china.unity3d.com/thread-27044-1-1.html 在Unity开发Android应用优化指南(上)一文中,从游戏性能,脚本等方面进行了分析和总结 ...
- Android开发权威指南(第2版)新书发布
<Android 开发权威指南(第二版)>是畅销书<Android开发权威指南>的升级版,内容更新超过80%,是一本全面介绍Android应用开发的专著,拥有45 章精彩内容供 ...
- 最全面的 Android 编码规范指南
最全面的 Android 编码规范指南 本文word文档下载地址:http://pan.baidu.com/s/1bXT75O 1. 前言 这份文档参考了 Google Java 编程风格规范和 Go ...
- Android SDK 开发指南
Android SDK 开发指南 视频详解 以下视频是对融云 Android SDK 开发使用的详细讲解,您可以在阅读文档时配合学习. 更多视频教程如下: CSDN 融云 Android SDK ...
随机推荐
- sql中left join、right join、inner join的区别
转自https://www.cnblogs.com/pcjim/articles/799302.html left join.right join.inner join区别 left join(左联 ...
- sar性能监控
1.安装sar: yum -y install sysstat 第一次使用sar命令会提示如下错误:“无法打开 /var/log/sa/sa13: 没有那个文件或目录”. 这里的值13是当天的日期,如 ...
- HBase 集群监控系统构建
HBase 集群监控系统构建 标签(空格分隔): Hbase 一, 集群为什么需要监控系统 总的来说是为了保证系统的稳定性,可靠性,可运维性.具体来说我认为有以下几点: 掌控集群的核心性能指标,了解集 ...
- NOIP2018初赛划水记
尽管初赛好像没什么好写的,但还是以此作为我的第一篇游记吧. 前夜 本来以为初赛水(去年分数线36来着),几周前做了一套普及组的卷子90多分感觉良好就没管了(不明白那些专门花时间看初赛书的人),结果Mr ...
- 【零售App】—— react/ant design mobile项目爬坑
一.H5制作 - 图片文本的动画效果 bug:打开一个模板,添加图片,添加动画效果,若先选定动画效果,再调节动画时间和延迟时间,则动画和延迟时间没有改变:若先调节动画时间和延迟时间在选定动画效果,则动 ...
- zabbix 监控安装部署
今天尝试一下部署zabbix 官方文档包括多个版本,此处选择4.0版本 https://www.zabbix.com/documentation/4.0/manual 1.安装环境选择 zabbix4 ...
- Python深度学习读书笔记-5.Keras 简介
Keras 重要特性 相同的代码可以在 CPU 或 GPU 上无缝切换运行. 具有用户友好的 API,便于快速开发深度学习模型的原型. 内置支持卷积网络(用于计算机视觉).循环网络(用于序列处理)以及 ...
- iOS应用将强制使用HTTPS安全加密-afn配置https(190926更新)
WWDC 2016苹果开发者大会上,苹果在讲解全新的iOS10中提到了数据安全这一方面,并且苹果宣布iOS应用将从2017年1月起启用名为App Transport Security的安全传输功能. ...
- Docker安装CentOS7
1. 拉取镜像 docker pull centos:centos7 2. 启动镜像创建容器 docker run -d -p 36622:22 -p 36680:80 --name centos7- ...
- Hibernate一级缓冲
Hibernate的一级缓冲 什么是缓冲 缓冲概念: 数据存在数据库中,数据库本身就是一个文件系统,使用流的方式操作文件,但是文件中有很多的内容,用流的操作得效率就低. 解决办法: 把数据存在内存中, ...