轻松上手,Android SQLite数据库实战攻略揭秘
Android 开发中,数据存储是不可或缺的一部分。SQLite 作为 Android 系统内置的轻量级数据库,因其简单易用、性能优越等特点,成为 Android 开发者的首选。本文将带你轻松上手 Android SQLite 数据库,并通过实战案例揭秘其应用技巧。…
Android 开发中,数据存储是不可或缺的一部分。SQLite 作为 Android 系统内置的轻量级数据库,因其简单易用、性能优越等特点,成为 Android 开发者的首选。本文将带你轻松上手 Android SQLite 数据库,并通过实战案例揭秘其应用技巧。
一、SQLite 简介

SQLite 是一个轻量级的数据库引擎,支持标准的 SQL 语句,具有体积小、速度快、易于使用等特点。在 Android 开发中,SQLite 可以通过 JDBC 驱动程序与 Java 代码进行交互。
二、Android 中使用 SQLite
1. 创建数据库
在 Android 中,可以使用 SQLiteOpenHelper 类来创建和管理数据库。以下是一个创建数据库的示例代码:
public class MyDatabaseHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "mydatabase.db";
private static final int DATABASE_VERSION = 1;
public MyDatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL("CREATE TABLE IF NOT EXISTS user ("
+ "id INTEGER PRIMARY KEY AUTOINCREMENT, "
+ "name TEXT NOT NULL, "
+ "age INTEGER NOT NULL)");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// 数据库升级逻辑
}
}2. 操作数据库
(1)插入数据
使用 insert 方法可以插入数据。以下是一个插入数据的示例代码:
public void insertData(String name, int age) {
SQLiteDatabase db = getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name", name);
values.put("age", age);
db.insert("user", null, values);
db.close();
}(2)查询数据
使用 query 方法可以查询数据。以下是一个查询数据的示例代码:
public List<User> queryData() {
List<User> userList = new ArrayList<>();
SQLiteDatabase db = getReadableDatabase();
Cursor cursor = db.query("user", new String[]{"id", "name", "age"}, null, null, null, null, null);
while (cursor.moveToNext()) {
int id = cursor.getInt(0);
String name = cursor.getString(1);
int age = cursor.getInt(2);
userList.add(new User(id, name, age));
}
cursor.close();
db.close();
return userList;
}(3)更新数据
使用 update 方法可以更新数据。以下是一个更新数据的示例代码:
public void updateData(int id, String name, int age) {
SQLiteDatabase db = getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name", name);
values.put("age", age);
db.update("user", values, "id=?", new String[]{String.valueOf(id)});
db.close();
}(4)删除数据
使用 delete 方法可以删除数据。以下是一个删除数据的示例代码:
public void deleteData(int id) {
SQLiteDatabase db = getWritableDatabase();
db.delete("user", "id=?", new String[]{String.valueOf(id)});
db.close();
}三、实战案例
以下是一个简单的 Android 应用,使用 SQLite 数据库存储用户信息。
创建一个名为
MainActivity的 Activity,并在其布局文件activity_main.xml中添加一个按钮和一个文本视图。在
MainActivity中,编写以下代码:
public class MainActivity extends AppCompatActivity {
private SQLiteDatabase db;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
MyDatabaseHelper dbHelper = new MyDatabaseHelper(this);
db = dbHelper.getWritableDatabase();
Button insertButton = findViewById(R.id.insert_button);
insertButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
insertData("张三", 20);
Toast.makeText(MainActivity.this, "插入数据成功!", Toast.LENGTH_SHORT).show();
}
});
Button queryButton = findViewById(R.id.query_button);
queryButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
List<User> userList = queryData();
StringBuilder sb = new StringBuilder();
for (User user : userList) {
sb.append("ID: ").append(user.getId()).append(", ")
.append("姓名: ").append(user.getName()).append(", ")
.append("年龄: ").append(user.getAge()).append("\n");
}
TextView textView = findViewById(R.id.text_view);
textView.setText(sb.toString());
}
});
}
private void insertData(String name, int age) {
SQLiteDatabase db = getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name", name);
values.put("age", age);
db.insert("user", null, values);
db.close();
}
private List<User> queryData() {
List<User> userList = new ArrayList<>();
SQLiteDatabase db = getReadableDatabase();
Cursor cursor = db.query("user", new String[]{"id", "name", "age"}, null, null, null, null, null);
while (cursor.moveToNext()) {
int id = cursor.getInt(0);
String name = cursor.getString(1);
int age = cursor.getInt(2);
userList.add(new User(id, name, age));
}
cursor.close();
db.close();
return userList;
}
}运行应用,点击按钮插入数据,再点击按钮查询数据,即可看到效果。
总结
本文介绍了 Android 中使用 SQLite 数据库的方法,并通过一个简单的实战案例展示了其应用。希望读者通过本文的学习,能够轻松上手 Android SQLite 数据库,并在实际项目中发挥其作用。








陕公网安备61012502000310号