安卓数据库编程详解 (安卓中的数据库编程)

安卓应用程序中大多数都要使用一些数据来存储信息,例如用户账户、应用程序设置和历史记录等。安卓平台中最常用的数据库管理系统是SQLite。在本文中,我们将详细介绍安卓数据库编程,包括SQLite的使用、数据库操作的基本知识和更佳的编程实践。我们还将演示如何使用SQLite进行CRUD操作(创建,读取,更新和删除)。

SQLite 在安卓中的使用

SQLite 是一种轻型的数据库管理系统,适用于嵌入式设备、移动应用程序和小型数据管理应用。同时,SQLite 是一个开源的、零配置的、自包含的、事务性的 SQL 数据库引擎。该数据库引擎的代码可在公共领域内使用,没有版权限制。由于SQLite轻量、易于集成和使用,所以在安卓平台中得到了广泛的使用。而且它的数据存储方式是文本文件,非常便于管理和备份。

SQLite通常是通过以下步骤来使用的:

1.创建对 SQLite 的引用。

2.打开 SQLite 数据库。

3.进行数据操作(例如创建表、插入、更新、删除等)。

4.关闭连接。

创建对 SQLite 的引用

在 Android Studio 中使用 SQLite,我们首先需要创建一个对 SQLite 的引用。为此,我们需要:

1.在 app/build.gradle 中添加以下依赖项:

dependencies {

implementation ‘androidx.sqlite:sqlite:2.0.1’

}

2.在要使用 SQLite 的 Java 类中导入以下包:

import androidx.sqlite.db.SupportSQLiteDatabase;

import androidx.sqlite.db.SupportSQLiteOpenHelper;

import androidx.sqlite.db.SQLiteOpenHelper;

打开 SQLite 数据库

在创建对 SQLite 的引用之后,我们需要打开数据库,并执行相应的操作。要打开 SQLite 数据库,我们使用了 Android 提供的 SQLiteOpenHelper 类。这个类可以创建、打开和升级 SQLite 数据库,它是一个抽象类,需要自己实现几个方法。

例如,以下代码片段演示了如何使用 SQLiteOpenHelper 打开 SQLite 数据库:

public class MySQLiteHelper extends SQLiteOpenHelper {

//构造函数

public MySQLiteHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {

super(context, name, factory, version);

}

//在这个方法中创建数据库

@Override

public void onCreate(SQLiteDatabase db) {

db.execSQL(“CREATE TABLE student (_id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, gender TEXT)”);

}

//升级数据库,更新数据库的表结构或数据

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

db.execSQL(“DROP TABLE student”);

onCreate(db);

}

}

这里我们定义了一个名为 MySQLiteHelper 的类,继承 SQLiteOpenHelper 抽象类,用于创建和升级数据库。然后我们需要调用该类来打开数据库:

MySQLiteHelper helper = new MySQLiteHelper(getApplicationContext(), “my_db_name”, null, 1); //创建一个数据库helper, 里面传入的参数分别是:上下文, 数据库名称, 数据库版本号

SQLiteDatabase db = helper.getWritableDatabase(); //打开数据库

进行数据操作

打开安卓数据库之后,我们就可以对它进行数据操作了。安卓提供了许多 SQL 的操作方式。

1.创建表

我们可以使用 CREATE TABLE 语句来创建一个 SQLite 数据库表。下面是一个创建学生表的示例:

db.execSQL(“CREATE TABLE student (_id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER, gender TEXT)”);

该语句创建了一个名为 student 的表,包括以下列:

_id:自动增长的 ID 列。

name:字符串列,用于存储学生的名称。

age:整数列,用于存储学生的年龄。

gender:字符串列,用于存储学生的性别。

2.插入数据

使用 INSERT INTO 语句来向表中添加数据。下面是一个向 student 表中插入一行数据的示例:

db.execSQL(“INSERT INTO student (name, age, gender) VALUES (‘小明’, 18, ‘男’)”);

3.查询数据

使用 SELECT 语句来查询数据库。下面是查询 student 表中所有数据的代码:

Cursor cursor = db.rawQuery(“SELECT * FROM student”, null); //返回的结果集是一个游标Cursor

while(cursor.moveToNext()) {

String name = cursor.getString(cursor.getColumnIndex(“name”)); //获取name列中的值

int age = cursor.getInt(cursor.getColumnIndex(“age”)); //获取age列中的值

String gender = cursor.getString(cursor.getColumnIndex(“gender”)); //获取gender列中的值

}

4.更新数据

使用 UPDATE 语句来更新数据库中的数据。下面是一个更新 student 表中数据的示例:

db.execSQL(“UPDATE student SET age = 18 WHERE name = ‘小明'”);

5.删除数据

使用 DELETE 语句来从数据库中删除数据。下面是一个删除 student 表中数据的示例:

db.execSQL(“DELETE FROM student WHERE name = ‘小明'”);

关闭连接

一定要关闭安卓数据库连接。释放占用的系统资源。这可以通过调用 SQLiteDatabase 对象的 close() 方法来实现。

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

更佳编程实践

– 使用事务:事务是数据库操作的一组操作。会把所有操作放在一个包中,这样如果有一个操作失败了,整个事务就不会执行。使用事务可以提高安卓数据库的性能和稳定性。

– 使用占位符:占位符表示数据的占位符,这样可以使 SQL 查询更加安全,避免 SQL 注入攻击。使用占位符可以让我们的代码更可读、更可维护、更健壮。例如:

String sql = “SELECT * FROM student WHERE name = ?”;

Cursor cursor = db.rawQuery(sql, new String[]{“小明”});

安卓平台使用 SQLite 作为数据库管理系统,可用于管理和操作移动应用程序中的数据。SQLite 是一个轻型的、开源的 SQL 数据库引擎,适用于嵌入式设备、移动应用程序和小型数据管理应用。在开始使用 SQLite 之前,我们需要创建对 SQLite 的引用,并且打开数据库,并通过 SQLiteOpenHelper 实现创建、升级和打开数据库。当我们打开数据库之后,我们可以使用 CREATE TABLE、INSERT、UPDATE、DELETE 和 SELECT 等 SQL 命令来对数据库进行操作。使用SQLite的事务可以提高数据库性能和稳定性。我们应该使用占位符来保护我们的应用程序免受 SQL 注入攻击。一定要关闭数据库连接。

相关问题拓展阅读:

android 开发里的 SQLite数据库的一段 查询记录总数,谁能讲解下?看不懂

android我没做过瞎蔽,但磨物州编程的原理一样吧,这是一个

返回值

为Long类型的方法,蚂银程序是一步一步执行额,之一行是获取数据库,第二行是执行SQL语句,第三个应该是移到最前端去执行(定位吧),第四个是获取结果中的之一行数据,关闭执行(或者说连接吧大概就是这么个意思),最后返回最终结果,个人理解,有出处见谅

//得到操作数据库的实例

SQLiteDatabase db = dbOpenHelper.getReadableDatabase();

// 调用查找书库代码并返回数据败梁指源

Cursor cursor = db.rawQuery(“察配select count(*)from person”,null);

//游标移到之一条记录准备获取数渣行据

cursor.moveToFirst();

// 获取数据中的LONG类型数据

Long count = cursor.getLong(0);

这些去查看Android的开发文档都有的

楼群为您辩誉精心挑选正品android 查看sqlite,android 查看sqliteandroid 开发里仿森的 SQLite数据库的一携大段段 查询记录总

关于安卓中的数据库编程的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » 安卓数据库编程详解 (安卓中的数据库编程)