创建SQLiteOpenHelper 类来创建和管理SQLite数据库

SQLite 是 Android 中用于存储数据的轻量级数据库。它是一个自包含的、无服务器的、零配置的 SQL 数据库引擎,广泛用于移动应用程序。

创建数据库

你可以通过扩展 SQLiteOpenHelper 类来创建和管理数据库。

java 复制代码
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) {  
        String CREATE_TABLE = "CREATE TABLE my_table (id INTEGER PRIMARY KEY, name TEXT)";  
        db.execSQL(CREATE_TABLE);  
    }  

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

插入数据

使用 SQLiteDatabase 对象插入数据。

java 复制代码
public void insertData(String name) {  
    SQLiteDatabase db = this.getWritableDatabase();  
    ContentValues values = new ContentValues();  
    values.put("name", name);  
    db.insert("my_table", null, values);  
    db.close();  
}  

查询数据

可以使用 Cursor 对象来查询数据。

java 复制代码
public Cursor getData() {  
    SQLiteDatabase db = this.getReadableDatabase();  
    return db.rawQuery("SELECT * FROM my_table", null);  
}  

更新和删除数据

更新和删除数据也可以通过 SQLiteDatabase 对象完成。

java 复制代码
public void updateData(int id, String newName) {  
    SQLiteDatabase db = this.getWritableDatabase();  
    ContentValues values = new ContentValues();  
    values.put("name", newName);  
    db.update("my_table", values, "id = ?", new String[]{String.valueOf(id)});  
    db.close();  
}  

public void deleteData(int id) {  
    SQLiteDatabase db = this.getWritableDatabase();  
    db.delete("my_table", "id = ?", new String[]{String.valueOf(id)});  
    db.close();  
}  
相关推荐
pokemon..1 小时前
MySQL主从复制与读写分离
数据库·mysql
码农鑫哥的日常1 小时前
MySQL高可用配置及故障切换
数据库·mysql
longlongqin1 小时前
redis的 stream数据类型实现 消息队列?
数据库·redis·缓存
wrx繁星点点1 小时前
多个线程同时写入一个共享变量,会发生什么问题?如何解决?
java·开发语言·数据库
鲨鱼辣椒ii1 小时前
sql中索引查看是否生效
数据库·sql
leidata2 小时前
MySQL系列—10.Innodb行格式
数据库·mysql
阿维的博客日记3 小时前
聚簇索引和二级索引
数据库·聚簇索引·二级索引
璇嘟嘟3 小时前
springboot-创建连接池
数据库
计算机程序设计开发3 小时前
小说阅读网站登录注册搜索小说查看评论前后台管理计算机毕业设计/springboot/javaWEB/J2EE/MYSQL数据库/vue前后分离小程序
数据库·vue.js·spring boot·java-ee·课程设计·计算机毕业设计·数据库管理系统
赵利伟@3 小时前
springboot对数据库进行备份+对一个文件夹内的文件按时间排序,只保留最近的8个文件
数据库