您的位置:

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

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

Android SQLite的增删改查操作详解

2023-05-19
使用Python实现Android SQLite的增删改查操

SQLite是一种轻量级的数据库,它可用于Android应用程序的本地数据存储。Python是一种高级编程语言,它可以与SQLite数据库进行交互。在本文中,我们将探讨如何使用Python在Andro

2023-12-08
Android SQLite 数据库操作详解

2023-05-18
使用Python操作Android Studio中的SQLi

一、关于SQLite数据库 SQLite 是一个轻量化的数据库管理系统,能够在本地存储数据并提供高效的数据更新、查询操作。Android系统中就使用了SQLite数据库来存储应用数据,在Android

2023-12-08
mysql的增删改查及编程,MySQL增删改查命令

2022-11-20
java增删改查,java增删改查实例项目

2023-01-10
mysql增删改查的实例,mysql怎么增删改查

2022-11-22
mysql数据库增删改(mysql数据库增删改查Androi

2022-11-10
学习Android Room数据库操作指南

在 Android 应用程序中,数据存储是无法避免的。你需要在你的应用程序中存储和管理用户数据。Android 为开发者提供了不同类型的存储选项,包括 Shared Preferences、文件存储、

2023-12-08
mysql数据库表增删改查,mysql增删改查

2022-11-23
MySQL增删改查语句的详解

2023-05-18
mysql的增删改查小程序(微信小程序增删改查)

2022-11-11
sqlite删除表详解

2023-05-23
SQLite删除表操作全解析

2023-05-22
使用Python操作Android SQLite数据库

2023-05-14
mysql数据库的增删改查代码(数据库的增删改查操作)

2022-11-13
使用mysql数据库增删改查(mysql数据库增删改查jsp

2022-11-13
C# Sqlite详解

2023-05-21
印象笔记记录java学习(Java成长笔记)

2022-11-12
php增加删除记录,php增删改

2023-01-06