Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【Android从零单排系列四十二】《Android数据存储方式-SQLite数据库》

【Android从零单排系列四十二】《Android数据存储方式-SQLite数据库》

作者头像
再见孙悟空_
发布于 2023-07-17 12:36:20
发布于 2023-07-17 12:36:20
34900
代码可运行
举报
运行总次数:0
代码可运行

前言

小伙伴们,在上文中我们介绍了Android数据存储中的ContentProvider,本文我们继续盘点介绍Android开发中的另一个数据存储方式SQLite数据库

一 SQLite数据库基本介绍

Android提供了SQLite数据库作为轻量级的嵌入式数据库解决方案,用于在应用程序中存储和管理结构化的数据。下面是关于SQLite数据库的一些重要信息:

  1. 数据库创建:可以使用SQLiteOpenHelper类来创建和管理数据库。它提供了创建数据库、升级数据库版本等功能。
  2. 数据表创建:在数据库中,需要创建表来存储数据。可以使用SQL语句或通过创建Java对象来定义表的结构。
  3. 数据库操作:可以使用SQLiteDatabase类执行各种数据库操作,包括插入、查询、更新和删除数据。通过构建适当的SQL语句和参数化查询,可以实现对数据库的操作。
  4. 事务管理:可以使用事务来确保数据库的一致性和数据完整性。通过开始事务、提交事务或回滚事务的方式来管理数据库操作。
  5. 数据库版本管理:如果需要修改数据库结构或添加新表,可以通过增加数据库版本号,并在SQLiteOpenHelper的onUpgrade方法中执行相应的数据库升级操作。
  6. 数据库查询:可以使用SQL语句进行复杂的数据库查询操作,包括联合查询、排序、过滤和分组等。也可以使用query方法来构建更灵活的查询条件。
  7. 数据库迁移:当应用程序升级时,可能需要对数据库进行迁移操作,以保持数据的一致性。可以使用SQLiteOpenHelper的onUpgrade方法来执行迁移逻辑。
  8. 数据库性能优化:为了提高数据库的性能,可以使用索引来加速查询操作,合理设计表结构和关系,避免频繁的数据库操作。
  9. 异步操作:对于耗时的数据库操作,建议在后台线程中执行,以避免阻塞UI线程。可以使用AsyncTask、线程池或RxJava等方式来实现异步数据库操作。

二 SQLite数据库使用方法

  1. 创建数据库和表:
    • 创建一个继承自SQLiteOpenHelper的子类,并实现它的构造方法、onCreate()和onUpgrade()等方法。
    • 在onCreate()方法中,使用SQL语句创建数据库和表,例如:CREATE TABLE语句。
    • 在构造方法中指定数据库名称、版本号和表结构等信息,并调用父类的构造方法。
  2. 获取数据库实例:
    • 在你的应用程序中,通过实例化你创建的SQLiteOpenHelper子类,获取一个数据库实例对象,例如:SQLiteDatabase db = dbHelper.getWritableDatabse()。
  3. 执行数据库操作:
    • 对于插入数据,可以使用insert()方法,例如:db.insert(tableName, nullColumnHack, values)。
    • 对于查询数据,可以使用query()方法,例如:db.query(tableName, columns, selection, selectionArgs, groupBy, having, orderBy)。
    • 对于更新数据,可以使用update()方法,例如:db.update(tableName, values, whereClause, whereArgs)。
    • 对于删除数据,可以使用delete()方法,例如:db.delete(tableName, whereClause, whereArgs)。
    • 也可以使用execSQL()方法执行自定义的SQL语句。
  4. 处理事务:
    • 如果需要执行一系列的数据库操作,为了确保数据的一致性和完整性,可以使用事务管理。通过调用beginTransaction()开始事务,在所有操作完成后调用setTransactionSuccessful()表示事务成功,并最后调用endTransaction()来结束事务。
  5. 关闭数据库:
    • 在不再需要使用数据库时,通过调用close()方法来关闭数据库连接,例如:db.close()。

这些是SQLite数据库的基本使用方法。你可以根据自己的具体需求,使用合适的SQL语句和API来完成数据库的增删改查操作。同时,要确保在进行数据库操作时遵循良好的数据库设计原则,并注意处理异常情况以及对数据库性能进行优化。

三 SQLite数据库常见属性及方法

  1. 属性:
    • Database Name:数据库名称。
    • Database Version:数据库版本号。
    • Table Name:表名称。
    • Column Names:列名称。
  2. 方法:
    • SQLiteOpenHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version):构造方法,用于创建SQLite数据库的辅助类对象。
    • onCreate(SQLiteDatabase db):当数据库第一次创建时调用,可以在其中执行创建表的操作。
    • onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion):在数据库版本更新时调用,可以在其中执行数据迁移或更新表结构的操作。
    • getWritableDatabase():获取可写入的数据库实例。
    • getReadableDatabase():获取可读取的数据库实例。
    • close():关闭数据库连接。
    • execSQL(String sql):执行自定义的SQL语句。
    • insert(String table, String nullColumnHack, ContentValues values):插入数据到指定表中。
    • query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy):查询指定表中的数据。
    • update(String table, ContentValues values, String whereClause, String[] whereArgs):更新指定表中的数据。
    • delete(String table, String whereClause, String[] whereArgs):从指定表中删除数据。
    • beginTransaction():开始事务。
    • setTransactionSuccessful():设置事务标记为成功。
    • endTransaction():结束事务。

四 SQLite数据库简单案例

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.content.ContentValues;

public class MyDatabaseHelper extends SQLiteOpenHelper {
    private static final String DATABASE_NAME = "myDatabase.db";
    private static final int DATABASE_VERSION = 1;
    private static final String TABLE_NAME = "myTable";
    private static final String COLUMN_ID = "id";
    private static final String COLUMN_NAME = "name";

    public MyDatabaseHelper(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        String createTableQuery = "CREATE TABLE " + TABLE_NAME + " (" +
                COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " +
                COLUMN_NAME + " TEXT)";
        db.execSQL(createTableQuery);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // 如果数据库版本更新,可以在此进行数据迁移或更新表结构的操作
        // 这里仅删除并重新创建表格来演示
        db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME);
        onCreate(db);
    }

    public void insertData(String name) {
        SQLiteDatabase db = getWritableDatabase();
        ContentValues values = new ContentValues();
        values.put(COLUMN_NAME, name);
        db.insert(TABLE_NAME, null, values);
        db.close();
    }

    public Cursor getAllData() {
        SQLiteDatabase db = getReadableDatabase();
        return db.query(
            TABLE_NAME,
            null,
            null,
            null,
            null,
            null,
            null
        );
    }
}

// 示例用法:
public class MainActivity extends AppCompatActivity {
    private MyDatabaseHelper dbHelper;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        dbHelper = new MyDatabaseHelper(this);

        // 插入数据
        dbHelper.insertData("John");
        dbHelper.insertData("Anna");
        dbHelper.insertData("Peter");

        // 查询数据并显示
        Cursor dataCursor = dbHelper.getAllData();
        if (dataCursor != null && dataCursor.moveToFirst()) {
            do {
                int id = dataCursor.getInt(dataCursor.getColumnIndex("id"));
                String name = dataCursor.getString(dataCursor.getColumnIndex("name"));
                Log.d("MainActivity", "ID: " + id + ", Name: " + name);
            } while (dataCursor.moveToNext());
        }

        // 关闭数据库连接
        dbHelper.close();
    }
}

这个案例演示了如何创建一个名为"myTable"的表格,并向表中插入几条数据。然后,通过查询获取所有数据,并在控制台打印出每条数据的ID和名称。最后,通过调用dbHelper.close()关闭数据库连接。

五 总结

总体而言,Android SQLite数据库是一种灵活、可靠且功能强大的嵌入式数据库解决方案。它适用于存储小型到中型数据集,并提供了广泛的API和功能来满足应用程序的需求。合理使用SQLite数据库可以提升应用程序的数据管理和存储能力,同时需要注意数据库设计和性能优化。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-07-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
利用SQLChiper对Android SQLite数据库加密
利用SQLChiper对Android SQLite数据库加密 前言: 上篇文章讲了Android studio+SQLCipher加密SQLite数据库的几个坑,跳过这几个坑,那么SQLCipher的前提就处理完成,本片文章接着讲如何使用SQLCiper加密数据库。
红目香薰
2022/11/29
1K0
2014-10-27Android学习------SQLite数据库操作(二)-----数据库的创建--SQLiteHelper extends SQLiteOpenHelper
上篇有篇文章讲了数据库的操作 条件是:数据库已经建好的了,我们只需要从里面获取数据(查询)就可以了,
wust小吴
2022/03/07
7770
2014-10-27Android学习------SQLite数据库操作(二)-----数据库的创建--SQLiteHelper extends SQLiteOpenHelper
Android SQLite数据库
SQLiteOpenHelper 抽象类有两个抽象方法:onCreate() onUpgrade() 创建和升级数据库
SakuraTears
2022/01/13
2.2K0
Android网络与数据存储——SQLite
Android提供了一个管理数据库的工具类SQLiteOpenHelper,用于管理数据库的创建和版本更新,创建SQLiteOpenHelper的子类,并实现它的onCreate()和onUpgrade()方法。通过该子类的getReadableDatabase()、getWriteableDatabase()方法打开数据库,获取对应的SQLiteDatabase对象。
trampcr
2018/09/28
1.7K0
安卓开发_数据存储技术_sqlite
一、SQLite SQLite第一个Alpha版本诞生于2000年5月,它是一款轻量级数据库,它的设计目标是嵌入式的,占用资源非常的低,只需要几百K的内存就够了。SQLite已经被多种软件和产品使用 二、SQLite特性 1 2 1、轻量级 3 SQLite和C\S模式的数据库软件不同,它是进程内的数据库引擎,因此不存在数据库的客户端和服务器。使用SQLite一般只需要带上它的一个动态库,就可以享受它的全部功能。而且那个动态库的尺寸也相当小。 4 2、独立性 5 SQLite数据库的核心引擎本身不
听着music睡
2018/05/18
8830
Android中SQLite数据库小计
用户1172465
2018/01/05
2.2K0
Carson带你学Android:SQLlite数据库操作全解析(SQLiteOpenHelper类)
###4.1 具体代码如下: 建议先下载Demo再进行阅读:Carson的Github:DataBase_Demo
Carson.Ho
2022/03/24
1K0
Carson带你学Android:SQLlite数据库操作全解析(SQLiteOpenHelper类)
【Android开发基础系列】Sqlite基础专题
       在Android开发中SQLite起着很重要的作用,网上SQLite的教程有很多很多,不过那些教程大多数都讲得不是很全面。本人总结了一些SQLite的常用的方法,借着论坛的大赛,跟大家分享分享的。
江中散人_Jun
2023/10/16
2940
【Android开发基础系列】Sqlite基础专题
【Android 应用开发】Android 数据存储 之 SQLite数据库详解
转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/19028665
韩曙亮
2023/03/27
2.7K0
【Android 应用开发】Android 数据存储 之 SQLite数据库详解
2014-10-27Android学习------SQLite数据库操作(三)-----数据库模块
以后需要数据库的时候把这两个类放到一个com.xx.xx.db包下,更改里面的数据库名称等,有效的管理自己的代码
wust小吴
2022/03/07
2520
【鼠】安卓学习杂记(十三)——Android数据存储之SQLite数据库存储
轻量级嵌入式数据库引擎,它支持SQL 语言,并且只利用很少的内存就有很好的性能。可存储大量的数据。
訾博ZiBo
2025/01/06
920
【鼠】安卓学习杂记(十三)——Android数据存储之SQLite数据库存储
Android:SQLiteOpenHelper类(SQLlite数据库操作)详细解析
当我们完成了对数据库的操作后,记得调用SQLiteDatabase的close()方法释放数据库连接,否则容易出现SQLiteException。
Carson.Ho
2019/02/22
31.2K3
Android SQLite数据库基本用法详解
public class DBHelper extends SQLiteOpenHelper{
奶油话梅糖
2021/03/16
2.2K0
android之存储篇_SQLite存储方式「建议收藏」
大家好,又见面了,我是全栈君。SQLite是一种转为嵌入式设备设计的轻型数据库,其只有五种数据类型,分别是:
全栈程序员站长
2022/07/20
1.2K0
android之存储篇_SQLite存储方式「建议收藏」
android学习笔记----SQLite数据库
目录一二的增删改查源码地址:https://github.com/liuchenyang0515/CreateDB3
砖业洋__
2023/05/06
1.1K0
android学习笔记----SQLite数据库
笔记30 | 数据存储之SQLite的介绍及使用
前言 零零散散钻研了2天的SQLite的,终于有个基本的认识,说来没脸,正式工作20个月了,还真没用过的SQLite存储数据,因为我负责的公司项目都不需要联网,没有什么复杂的数据需存储,一般用SharedPreferences处理就行了! 前人栽树 http://www.jianshu.com/p/5c33be6ce89d http://blog.csdn.net/codeeer/article/details/30237597/ 目录 SQLite的介绍 SQLiteDatabase的介绍 一步一步实现
项勇
2018/06/19
8190
Android SQLite 数据库学习
  SQLite 是一个轻量级数据库,它是D. Richard Hipp建立的公有领域项目,在2000年发布了第一个版本。它的设计目标是嵌入式的,而且占用资源非常低,在内存中只需要占用几百kB的存储空间,这也是Android移动设备采用SQLite数据库的重要原因之一。
星哥玩云
2022/08/17
1.3K0
SQlite数据库简介Android网络与数据存储
SQLite看名字就知道是个数据库,Android专门为移动端内置了此种轻量级工具,并且为了方便在Java语言中进行数据库操作,编写了SQLiteOpenHelper类来方便在Android中操作数据库”
爱因斯坦福
2018/09/10
1K0
数据存储之-SQLite数据库一
对于涉及数据库的app,我们不可能手动地去给他创建数据库文件,所以需要在第一次启用app 的时候就创建好数据库表;而当我们的应用进行升级需要修改数据库表的结构时,这个时候就需要 对数据库表进行更新了;对于这两个操作,安卓给我们提供了SQLiteOpenHelper的两个方法, onCreate( )与onUpgrade( )来实现
小小工匠
2021/08/16
7430
Android数据读取之Sqlite数据库操作
咱们书接上文,继续来说说Android数据读取,这回,我们要讲的是Sqlite数据库的相关操作。以一个实例开始吧:
牛老师讲GIS
2018/10/23
1.6K0
Android数据读取之Sqlite数据库操作
推荐阅读
相关推荐
利用SQLChiper对Android SQLite数据库加密
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验