当前位置: 首页 > article >正文

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

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

创建数据库

你可以通过扩展 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) {  
        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 对象插入数据。

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 对象来查询数据。

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

更新和删除数据

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

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();  
}  


http://www.kler.cn/a/284181.html

相关文章:

  • Vue.js 项目创建流程
  • HTTP常见的请求头有哪些?都有什么作用?在 Web 应用中使用这些请求头?
  • 什么时候需要复写hashcode()和compartTo方法
  • 一文简单了解Android中的input流程
  • -1大于4?负数与无符号整数类型:size_t的比较问题(strlen)
  • 【C#设计模式(8)——过滤器模式(Adapter Pattern)】
  • vue2踩坑记录:el-select如何绑定对象
  • 二叉树详解(2)
  • Ethercat设备数据 转IEC61850项目案例
  • zyx青岛实训day34 初步了解Docker与套接字的应用
  • 行为模式7.解释器模式------DSL语言
  • Linux动态库搜索路径相关知识文章
  • UE4 使用AndroidGameDevelopmentExtension(AGDE)对安卓客户端做“断点调试”与“代码热更”
  • Nginx代理MinIO界面
  • Vue.js入门系列(十八):利用浏览器本地存储实现TodoList数据持久化
  • 全国设计院排名 境外工程总承包营业额二〇二三年排名
  • 在 Deepin 系统中搭建 Node.js 开发环境
  • 【STM32】RTC
  • 打卡第60天------图论
  • OceanBase V4 技术解读:从Alter Table 看DDL的支持
  • Linux CentOS 添加路由
  • 江协科技stm32————10-3 软件I2C读写MPU6050
  • 2 Python开发工具:PyCharm的安装和使用
  • 【知识】对比Share mem/Pin mem/GPU mem之间的传输速度
  • TinTinLand Web3 + DePIN 共学月|挖掘 CESS 去中心化数据基础设施。
  • Jmeter进行http接口测试