安卓数据库编程详解 (安卓中的数据库编程)
安卓应用程序中大多数都要使用一些数据来存储信息,例如用户账户、应用程序设置和历史记录等。安卓平台中最常用的数据库管理系统是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 注入攻击。一定要关闭数据库连接。