Android SQLite的增删改查操作详解

什么是Android SQLite

SQLite是一个关系型数据库管理系统,这个库是在用户空间运行的,因此,不像MySQL等需要在程序中安装对应的服务来进行通讯。SQLite虽然是个很小巧的数据库,但是在Android平台上面,使用得却是异常广泛。因为SQLite的轻便性能特别适合在移动设备上面承载一些小型的数据管理,并且它的设计很符合Android系统的设计。

Android SQLite的应用场景

针对储存半结构化或非结构化数据,如配置文件、用户数据、环境变量等信息。

非常适用于本地APP运行数据的存储。如果需要将数据共享,可以使用SQL、Web API等技术。

Android SQLite基础操作

创建SQLiteOpenHelper类

SQLiteOpenHelper类是Android提供的一个帮助类,它提供了一个获取数据库实例的方法,并且它可以让我们很方便的打开数据连接。创建SQLiteOpenHelper 类,我们需要继承它并且实现其抽象方法,如下:

public class MyDatabaseHelper extends SQLiteOpenHelper {
    private static final String DB_NAME = "test.db"; // 数据库名称
    private static final int DB_VERSION = 1; // 数据库版本号

    public MyDatabaseHelper(Context context) {
        super(context, DB_NAME, null, DB_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("CREATE TABLE IF NOT EXISTS t_user (_id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, age INTEGER DEFAULT 0);");
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        db.execSQL("DROP TABLE IF EXISTS t_user;");
        onCreate(db);
    }
}

在上述代码中,我们创建了一个继承自SQLiteOpenHelper的自定义帮助类MyDatabaseHelper,实现了其两个方法onCreate和onUpgrade,其中,onCreate方法会在首次创建数据库时被调用,用于在数据库中创建相关的表和列。onUpgrade方法会在当前数据库版本较低时,被SQLiteOpenHelper调用。

打开或创建数据库

通过继承自SQLiteOpenHelper并实现部分方法,我们可以打开或创建数据库,并进行相应的操作,如下:

MyDatabaseHelper dbHelper = new MyDatabaseHelper(context);
SQLiteDatabase db = dbHelper.getWritableDatabase();

在上述代码中,我们创建一个MyDatabaseHelper实例,并调用其getWritableDatabase方法,获取可写的数据库连接(如若只读请改用getReadableDatabase)。如果数据库不存在就会自动创建,否则直接打开该数据库,并返回一个SQLiteDatabase实例。

插入数据

SQLite提供了insert()方法可以插入数据,当然,在插入数据之前我们还需要创建对应的表和列。

SQLiteDatabase db = dbHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name", "张三");
values.put("age", "25");
db.insert("t_user", null , values);

在上述代码中,我们首先获取到一个SQLiteDatabase对象,然后创建ContentValues对象,将要插入的数据封装进去。最后,我们调用insert方法把数据插入到表t_user中。

查询数据

SQLite提供了query()方法来查询数据,该方法有多个重载方法来满足不同的查询需求。在这里我们看下最常用的两种查询方式:

查询所有数据:

SQLiteDatabase db = dbHelper.getWritableDatabase();
Cursor cursor = db.query("t_user", null, null, null, null, null, null);
if (cursor.moveToFirst()) {
    do {
        String name = cursor.getString(cursor.getColumnIndex("name"));
        int age= cursor.getInt(cursor.getColumnIndex("age"));
        Log.d(TAG, "name: " + name + ", age: " + age);
    } while (cursor.moveToNext());
}
cursor.close();

在上述代码中,我们调用了query()方法来查询t_user表中所有的数据,并使用Cursor对象遍历结果,从每行中提取所有数据的name和age字段。查询完成后,需要记得调用close()方法来关闭Cursor对象。

按条件查询数据:

SQLiteDatabase db = dbHelper.getWritableDatabase();
Cursor cursor = db.query("t_user", null, "age>?", new String[]{"18"}, null, null, null);
if (cursor.moveToFirst()) {
    do {
        String name = cursor.getString(cursor.getColumnIndex("name"));
        int age= cursor.getInt(cursor.getColumnIndex("age"));
        Log.d(TAG, "name: " + name + ", age: " + age);
    } while (cursor.moveToNext());
}
cursor.close();

在上述代码中,我们传递了参数来获取符合指定条件的行。query()方法的第3个参数为where子句,而第4个参数是where子句的每个参数的值。在这里,我们只返回age字段大于18的所有人的姓名和年龄。

修改数据

SQLite provides update()方法来更新数据。在更新记录之前,我们需要先找到将要更新的记录。在这里我们看下最常用的两种更新方式:

更新一个字段:

SQLiteDatabase db = dbHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name", "李四");
db.update("t_user", values, "_id=?", new String[]{"1"});

在上述代码中,我们修改id为1的行中的name字段,并将它的值设为“李四”。

更新多个字段:

SQLiteDatabase db = dbHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name", "王五");
values.put("age", "30");
db.update("t_user", values, "_id=?", new String[]{"1"});

在上述代码中,我们修改id为1的行中的name和age字段,分别赋值为“王五”和“30”。

删除数据

SQLite提供了delete()方法来删除数据,该方法的第一个参数是表名,第二个参数是where子句,第三个参数是where子句的每个参数的值。在这里我们看下最常用的方式:

SQLiteDatabase db = dbHelper.getWritableDatabase();
db.delete("t_user", "age<?", new String[]{"18"});

在上述代码中,我们删除t_user表中age小于18的所有行。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/232521.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-11 12:52
下一篇 2024-12-11 12:52

相关推荐

  • Python栈操作用法介绍

    如果你是一位Python开发工程师,那么你必须掌握Python中的栈操作。在Python中,栈是一个容器,提供后进先出(LIFO)的原则。这篇文章将通过多个方面详细地阐述Pytho…

    编程 2025-04-29
  • Python操作数组

    本文将从多个方面详细介绍如何使用Python操作5个数组成的列表。 一、数组的定义 数组是一种用于存储相同类型数据的数据结构。Python中的数组是通过列表来实现的,列表中可以存放…

    编程 2025-04-29
  • Python操作MySQL

    本文将从以下几个方面对Python操作MySQL进行详细阐述: 一、连接MySQL数据库 在使用Python操作MySQL之前,我们需要先连接MySQL数据库。在Python中,我…

    编程 2025-04-29
  • Python代码实现回文数最少操作次数

    本文将介绍如何使用Python解决一道经典的回文数问题:给定一个数n,按照一定规则对它进行若干次操作,使得n成为回文数,求最少的操作次数。 一、问题分析 首先,我们需要了解回文数的…

    编程 2025-04-29
  • Python磁盘操作全方位解析

    本篇文章将从多个方面对Python磁盘操作进行详细阐述,包括文件读写、文件夹创建、删除、文件搜索与遍历、文件重命名、移动、复制、文件权限修改等常用操作。 一、文件读写操作 文件读写…

    编程 2025-04-29
  • Python元祖操作用法介绍

    本文将从多个方面对Python元祖的操作进行详细阐述。包括:元祖定义及初始化、元祖遍历、元祖切片、元祖合并及比较、元祖解包等内容。 一、元祖定义及初始化 元祖在Python中属于序…

    编程 2025-04-29
  • 如何用Python对数据进行离散化操作

    数据离散化是指将连续的数据转化为离散的数据,一般是用于数据挖掘和数据分析中,可以帮助我们更好的理解数据,从而更好地进行决策和分析。Python作为一种高效的编程语言,在数据处理和分…

    编程 2025-04-29
  • Python列表的读写操作

    本文将针对Python列表的读取与写入操作进行详细的阐述,包括列表的基本操作、列表的增删改查、列表切片、列表排序、列表反转、列表拼接、列表复制等操作。 一、列表的基本操作 列表是P…

    编程 2025-04-29
  • Python序列的常用操作

    Python序列是程序中的重要工具,在数据分析、机器学习、图像处理等很多领域都有广泛的应用。Python序列分为三种:列表(list)、元组(tuple)和字符串(string)。…

    编程 2025-04-28
  • Python获取Flutter上内容的方法及操作

    本文将从以下几个方面介绍Python如何获取Flutter上的内容: 一、获取Flutter应用数据 使用Flutter提供的Platform Channel API可以很容易地获…

    编程 2025-04-28

发表回复

登录后才能评论