我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android持久化存储(3)SQLite数据库的使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android持久化存储(3)SQLite数据库的使用

1.什么是SQlite

SQLite是由C语言编写的一款轻型数据库,因占用资源小,处理速度快,功能齐全,特别适用于移动设备,最重要的是开源,任何人都可以使用它,许多开源项目(PHP,Python)和当今两大手机操作系统Android和iOS都使用了SQLite,造就了SQLite成为目前世界上最常见的数据库引擎。

2.SQLite特点

除了占用资源小,处理速度快等优点,SQLite还有自己的特点,那就是支持弱数据类型,其他主流SQL数据库通常支持强类型的数据,也就是每一列的类型都必须预先指定,如果输入的数据和指定数据类型对不上则报错,而SQLite采用的是弱类型,也就是说,创建一个表时指定某列的数据类型,但是你可以把任何数据类型插入该列,SQLite将检查它的类型,如果该类型与关联的列不匹配,则SQLite会尝试将该值转换成该列的类型,如果不能转换,则该值将作为其本身具有的类型存储。

SQLite支持数据类型如下:包括NULL、INTEGER、REAL、TEXT和BLOB

NULL: 该值是空值; INTEGER: 该值是一个有符号整数,根据值的大小以1、2、3、4、6或8个字节存储; REAL: 该值是一个浮点值,以8字节浮点数存储; TEXT: 该值是一个文本字符串,使用数据库编码(UTF-8,UTF-16BE或UTF-16LE)存储; BLOB: 值是BLOB数据块,以输入的数据格式进行存储。 3.Android使用SQLite

上文已说,Android集成了SQLite数据库,与此同时,Android还提供了使用SQLite数据库的API,可通过这些API可很方便的进行数据库操作。

3.1 SQLiteOpenHelper介绍

SQLiteOpenHelper是Android提供的SQLite帮助类,用于管理数据库(包括创建、增,删,改)和管理数据库的版本,方便开发者操作SQLite,SQLiteOpenHelper基本方法如下(更相信请参考官方文档https://developer.android.google.cn/reference/android/database/sqlite/SQLiteOpenHelper?hl=zh-cn)

方法名 描述
onCreate() 首次创建数据库时执行该方法,如果数据库不存在则创建,onCreate()方法在初次调用时才会被调用。重写onCreate()方法时,生成数据表结构
onUpgrade() 在需要升级数据库时调用方法,该方法检测数据库传入的版本号与当前的版本号是否相同,如果传入的版本号高于之前的版本,触发该方法
getReadableDatabase() 创建或者打开可读数据库
getWritableDatabase() 创建打开可读/写的数据库
close() 关闭所有打开的数据库对象

onCreat和onUpgrade是开发者实现,由SQLiteOpenHelper来调用。

其中onCreat是SQLiteOpenHelper在尝试找数据库时,如果没有找到则执行该方法,那么什么时候SQLiteOpenHelper去找数据库呢?是在创建SQLiteOpenHelper实例时,还是使用SQLiteOpenHelper的getWritableDatabase()或者getReadableDatabase()获取SQLiteDatabase时?

我们可以用代码来验证一下,我们在继承了SQLiteOpenHelper的MySQLiteOpenHelper代码里面添加一个flag作为标记,flag初始值是0,然后在构造函数里赋值成100,最后在onCreate中添加打印代码。然后我们在Activity里首先只实例化MySQLiteOpenHelper,不获取数据库,看是否触发了onCreate里的打印信息。之后再添加

java SQLiteDatabase sqLiteDatabase= mySQLiteOpenHelper.getWritableDatabase();
获取数据,再看打印信息。

Activity代码如下:

package com.test.sqlitedemo;
import androidx.appcompat.app.AppCompatActivity;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
public class MainActivity extends AppCompatActivity {
    MySQLiteOpenHelper mySQLiteOpenHelper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mySQLiteOpenHelper=new MySQLiteOpenHelper(this,"test",1);
    }
}

MySQLiteOpenHelper代码如下:

package com.test.sqlitedemo;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;
public class MySQLiteOpenHelper extends SQLiteOpenHelper {
    private int flag=0;
    
    public MySQLiteOpenHelper(Context context, String name, int version) {
        super(context, name, null, version);
        //这里赋值成100
        flag=100;
    }
    
    @Override
    public void onCreate(SQLiteDatabase db) {
        Log.d("MySQLiteOpenHelper", "flag="+flag);
        //新建数据表
        db.execSQL("create table translog(_id integer primary key autoincrement, transid , amount,date)");
        flag=50;
    }
    
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        Log.i("MySQLiteOpenHelper", oldVersion + "------->" + newVersion);
    }
}

验证结果是只实例化MySQLiteOpenHelper没有触发onCreate里的打印信息,在获取数据库的时候,SQLiteOpenHelper才会调用onCreate方法,关闭应用后再打开,也不会触发打印信息,因为数据库已经创建了。(这里验证半天,然后发现官网用一句话说清楚了什么时候创建数据库:

Create a helper object to create, open, and/or manage a database. This method always returns very quickly.

The database is not actually created or opened until one of getWritableDatabase() or getReadableDatabase() is called

再来看onUpgrade方法,该方法在数据库需要升级的时候调用,当传入SQLiteOpenHelper构造版本参数大于当前的版本时,触发该方法。升级数据库是开发者经常要面对的,而且多数时候在升级数据库时不能把之前的数据全部删掉,开发者可在onUpgrade函数里添加搬运数据的代码,在触发升级后执行里面的搬运逻辑。

有人可能会问了,SQLiteOpenHelper难道仅仅是帮忙检查数据库是否存在和升级数据库用到?如果只是这两个功能,虽然能帮开发者省点工作量,但并没有省多少工作啊!别忘了一句getWritableDatabase或者getWritableDatabase就可以获得数据库实例,换成其他平台操作数据库,还得慢慢拼凑数据库连接语句,这也省了不少工作量。其他数据库降级等也可以通过这个类操作,更具体请参考官方文档。

3.2 创建数据库

了解了SQLiteOpenHelper之后,便可以开始实践数据库之旅了。创建数据库代码见上边的onCreate里的创建SQL语句。该语句创建一个名为translog的表,用来记录交易日志,translog表有4列,分别是主键id,交易单号,金额和日期,注意到除了

_id
设置了为integer类型(因为要设置自增长主键),其他列都没指定,执行不会报错,这是SQLite弱数据类型的好处。

db.execSQL("create table translog(_id integer primary key autoincrement, transid , amount,date)");
3.3 添加数据

往表里添加数据有两种方法,一种使用原生SQL语句,往表里添加一条交易日志SQL语句如下

db.execSQL("INSERT INTO translog (transid, amount,date)"+ 
"VALUES ('955162020', 100.00,20200305)");

还有第二种也稍微简单移动的办法,那就是使用SQLiteDatabase对象的提供的insert(), update(),delete(),query()方法。这些方法其实是做了一层封装,最后还是内部转换成SQL语句完成插入数据操作。

添加数据insert(String table,String nullColumnHack,ContentValues values)有3个参数,其中:

参数1 表名; 参数2 空列的默认值; 参数3 ContentValues类型数据;

其中第二个参数nullColumnHack是空列的默认值,但又可以填null,我们知道,SQL不允许在不指定一个列名的情况下插入,例如***INSERT INTO translog ()VALUES ()")***是错的,如果第三个参数为空值,则会出现这种语法错误,第二个参数正是为了防止错误诞生,这样第三个参数为空值时,则使用第二个参数作为默认字段。那为什么又可以设置为null?这是在第三个参数values不为Null并且元素的个数大于0可以填的 。这个参数的思路是,如果你懒得检查第三个参数是否为空,那么填一个参数让我管,如果你填了一个null不让我管,那么你自己就要注意第三个参数不能为空。

第三个参数是ContentValues类型的数值,用法和map相似,提供了存取数据的put和get方法。注意键应该是表中存在的列名称。

下面是插入代码示例,注意到我们没给主键添加值,我们已经设置主键是自增长列,当没再ContentValues里给一个列put一个值时,相当于为该列添加一个null的值,主键自动增长,但是如果赋值了,则id设置成赋值后的值,建议让id自动增长,自己赋值不注意的话会导致id重复而报错。

//实例化常量值
ContentValues cValue = new ContentValues();
//添加交易单号
cValue.put("transid","9551620200307");
//添加消费金额
cValue.put("amount",100.00);
//添加交易日期
cValue.put("date",2020-03-07);
//调用insert()方法插入数据
db.insert("translog",null,cValue);
3.4 更新数据

更新数据当然也可用原生SQL语句然后使用execSQL() 方法可以达到目的,或者使用update()函数,函数的说明如下

int update(String table, ContentValues values, String whereClause, String[] whereArgs)
参数1 表名; 参数2 ContentValues类型数据; 参数3 WHERE表达式(String),指定需进行数据更新的行,其中?号是占位符,如果传递null将更新所有行; 参数4 填充第三个参数里的占位符,String[]数组类型;

例如想更新交易记录***9551620200307***的消费金额,可用如下代码实现

ContentValues replaceAmount = new ContentValues();
//要修改的金额
replaceAmount.put("amount","50.00");
//指定第3个参数里占位符?的内容,最后将翻译成transid=9551620200307
String[] parms=new String[] {"9551620200307"}; 
//执行更新
db.update("translog", replaceAmount, "transid=?", parms);
3.5 删除数据

经过熟悉增改函数后,发现函数都是有固定讨论的,删除函数delete和update函数参数很像,只不过少了要增加的参数,因为删除是破坏,破坏起来简单。

public int delete (String table, String whereClause, String[] whereArgs)
参数1 表名; 参数2 WHERE表达式(String),指定需进行删除的行,其中?号是占位符,如果传递null将删除所有行; 参数3 填充第二个参数里的占位符,String[]数组类型;

例如想删除交易记录***9551620200307***,可用如下代码实现

//指定第3个参数,也就是占位符?的内容,最后将翻译成transid=9551620200307
String[] parms=new String[] {"9551620200307"}; 
//执行更新
db.delete("translog", "transid=?", parms);
3.6 查询数据

查询方法放到最后,因为查询比较复杂,如果是查询全部数据还好,否则要指定各种条件。和前面的功能一样,查询也有两种方式,但要注意的是,原生查询SQL不支持db.execSQL,而是使用单独为查询设置的db.rawQuery方法,rawQuery方法两种类型,其中简单一点的原型如下:

 Cursor rawQuery (String sql, String[] selectionArgs)

其中第一个参数是SQL语句,第二个参数用于填充第一个参数里的占位符。rawQuery返回Cursor,最后再通过Cursor找到想要的查询结果。示例代码如下:

Cursor cursor = db.rawQuery("select * from transid",null); 
while(cursor.moveToNext()){
			int id=cursor.getInt(cursor.getColumnIndex("id"));
			String transid=cursor.getString(cursor.getColumnIndex("transid"));
            String amount=cursor.getString(cursor.getColumnIndex("amount"));
            String date=cursor.getString(cursor.getColumnIndex("date"));		
		}

rawQuery比较适用于简单查询,如果要设置更多条件,使用这个方法将会非常复杂。这个时候建议使用query方法,虽然参数比前面介绍的数据库增删改要多得多,但要比原生SQL查询语句可读性强。

来看其中一个query原型:

Cursor query (boolean distinct, 
                String table, 
                String[] columns, 
                String selection, 
                String[] selectionArgs, 
                String groupBy, 
                String having, 
                String orderBy, 
                String limit);

参数说明

distinct:指定是否过滤结果里的重复值,true过滤,false不过滤; table:表名 columns:指定想要查询的列的名称集; selection:WHERE之后的条件语句,可以使用占位符 selectionArgs:如果selection里有占位符,使用该参数填充 groupBy:指定分组的列名对,指定的话结果将按照列名分组 having:指定分组条件,配合groupBy使用 orderBy:指定排序的列名 limit:用于限定返回结果行数

除了table必须指定,其他参数都可以设置为null,这样等同于一句简单的

select * from table

结束语

SQLite因性能优秀占用体积小且开源被Android采用,如果Android程序需要保存大量数据,选择使用SQLite是一个明智的方案,Android针对SQLite封装了简单易用的API,其中SQLiteOpenHelper类用于创建和更新数据库,通过SQLiteOpenHelper,开发者不用纠结于创建数据库连接等繁琐的操作。在Android上,既可以选择使用原生SQL语句,也可以使用封装好的API操作,API包含了数据库的增删改查基本操作,通过使用API,不仅方便开发者,也增强了程序的可读性。不过,Android封装的API还是有点繁琐,目前已有大量好用的第三方库,可以更加方便操作数据库,这将会在后续介绍。


作者:风行南方


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android持久化存储(3)SQLite数据库的使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android持久化存储(3)SQLite数据库的使用

1.什么是SQlite SQLite是由C语言编写的一款轻型数据库,因占用资源小,处理速度快,功能齐全,特别适用于移动设备,最重要的是开源,任何人都可以使用它,许多开源项目(PHP,Python)和当今两大手机操作系统Android和iOS
2022-06-06

详解Android数据存储—使用SQLite数据库

SQLite是Android自带的关系型数据库,是一个基于文件的轻量级数据库。Android提供了3种操作数据的方式,SharedPreference(共享首选项)、文件存储以及SQLite数据库。 SQLite数据库文件被保存在/data
2022-06-06

Android数据存储之SQLite使用

SQLite是一款开源的、嵌入式关系型数据库,第一个版本Alpha发布于2000年。SQLite在便携性、易用性、紧凑性、高效性和可靠性方面有着突出的表现。 在Android中创建的SQLite数据库存储在:/data/data/<包名>/
2022-06-06

怎么在Android中对SQLite数据库进行数据持久化

怎么在Android中对SQLite数据库进行数据持久化?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、SQLiteOpenHelper:创建数据库和数据库版本管理的辅助
2023-05-31

Spring Data JPA数据持久化存储到数据库的方法

今天小编给大家分享一下Spring Data JPA数据持久化存储到数据库的方法的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧
2023-06-30

Android使用Sqlite存储数据用法示例

本文实例讲述了Android使用Sqlite存储数据的方法。分享给大家供大家参考,具体如下: 一般在开发程序中,经常使用数据的存储功能,如在使用Delphi开发程序时,存储程序的简单设置的INI文件,在C#开发中有时也需要存储简单的设置,个
2022-06-06

如何在Android中使用SQLite存储数据

这篇文章给大家介绍如何在Android中使用SQLite存储数据,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1. 安装一个SQLiteDeveloper,这个用来打开android生成的数据库。软件随便搜索就能找到,
2023-05-30

Netdata的监控数据是否支持持久化存储

是的,Netdata的监控数据支持持久化存储。 Netdata可以配置为将监控数据存储在本地磁盘上,以便稍后进行分析和检查。此外,Netdata还支持将监控数据发送到远程数据库,如InfluxDB或Graphite,以便进行更长期的存储和分
Netdata的监控数据是否支持持久化存储
2024-04-24

K8s中MySQL 数据持久化存储的实现

目录一、步骤二、实践2.1 创建 PV 和 PVC2.2 部署 mysql 服务2.3 创建测试数据2.4 模拟节点宕机2.5 数据一致性验证FAQ一、步骤(1)创建 PV 和 PVC。(2)部署 MySQL 服务。(3)向 MySQ
2023-01-09

Vue使用pinia管理数据pinia持久化存储问题

这篇文章主要介绍了Vue使用pinia管理数据pinia持久化存储问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-03-24

Android数据的四种存储方式之SQLite数据库

Test.java: /*** 本例解决的问题:* 核心问题:通过SQLiteOpenHelper类创建数据库对象* 通过数据库对象对数据库的数据的操作* 1.sql语句方式操作SQLite数据库* 2.谷歌提供的api对SQLite数据库
2022-06-06

K8s中MySQL 数据持久化存储的实现

本文主要介绍了K8s中MySQL 数据持久化存储的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-01-08

Spring Data JPA怎么实现持久化存储数据到数据库

这篇“Spring Data JPA怎么实现持久化存储数据到数据库”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Spring
2023-06-30

如何在Android开发中利用数据持久化存储文件

这期内容当中小编将会给大家带来有关如何在Android开发中利用数据持久化存储文件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。数据持久化数据持久化, 就是将内存中的瞬时数据保存在存储设备中, 保证即便关
2023-05-31

docker持久化存储数据的方法是什么

Docker提供了多种方法来实现持久化存储数据:1. 数据卷(Volumes):数据卷是一个特殊的目录,可以绕过容器文件系统来直接访问宿主机的文件系统。使用数据卷可以将容器内的数据持久化保存在宿主机上,并且可以在多个容器之间共享数据卷。可以
2023-10-27

Python中的数据对象持久化存储模块pickle的使用示例

Python中可以使用 pickle 模块将对象转化为文件保存在磁盘上,在需要的时候再读取并还原。具体用法如下: pickle是Python库中常用的序列化工具,可以将内存对象以文本或二进制格式导出为字符串,或者写入文档。后续可以从字符或文
2022-06-04

详解Android开发数据持久化之文件存储(附源码)

其实我们在社交网络上面所发出的任何信息, 都希望能够保留下来. 那么如何实现呢 数据持久化 数据持久化, 就是将内存中的瞬时数据保存在存储设备中, 保证即便关机之后, 数据仍然存在. 保存在内存中的数据是瞬时数据, 保存在存储设备中的数据就
2022-06-06

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录