数据存储-SQLiteOpenHelper

SQLiteOpenHelper数据库操作辅助类,本身是一个抽象类,抽象类无法直接实例化,所以通常都会自定义类,去继承抽象类,然后再实例化自定义的类。

public class MyHelper extends SQLiteOpenHelper {
    public MyHelper(@Nullable Context context, @Nullable String name, @Nullable SQLiteDatabase.CursorFactory factory, int version) {
        super(context, name, factory, version);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        String sql = "create table mytest(id integer"
                +" primary key autoincrement,"
                +" myusername varchar(10),"
                +" mypwd varchar(6))";
        db.execSQL(sql);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        Log.i("【数据库升级】", "onUpgrade: 数据库升级了");
    }
}

继承SQLiteOpenHelper抽象类后,必须要重新两个方法,onCreate和onUpgrade,第一个方法主要用于创建数据

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLiteOpenHelper的update方法用于更新数据库中的数据。 使用SQLiteOpenHelper的update方法,你需要执行以下步骤: 1. 获取SQLiteOpenHelper的实例。 2. 创建一个ContentValues对象,用于存储要更新的数据。 3. 调用SQLiteOpenHelper的getWritableDatabase方法获取可写的数据库实例。 4. 调用数据库实例的update方法,传入要更新的表名、要更新的数据、以及更新条件。 5. 关闭数据库连接。 下面是一个示例代码,演示如何使用SQLiteOpenHelper的update方法更新数据库中的数据: ```java public class MyDatabaseHelper extends SQLiteOpenHelper { public static final String DATABASE_NAME = "mydatabase.db"; public static final int DATABASE_VERSION = 1; public static final String TABLE_NAME = "mytable"; public static final String COLUMN_NAME = "name"; public static final String COLUMN_AGE = "age"; public MyDatabaseHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { // 创建数据库表 String createTableQuery = "CREATE TABLE " + TABLE_NAME + " (" + COLUMN_NAME + " TEXT, " + COLUMN_AGE + " INTEGER)"; db.execSQL(createTableQuery); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // 升级数据库 db.execSQL("DROP TABLE IF EXISTS " + TABLE_NAME); onCreate(db); } public void updateData(String name, int newAge) { SQLiteDatabase db = getWritableDatabase(); ContentValues values = new ContentValues(); values.put(COLUMN_AGE, newAge); String whereClause = COLUMN_NAME + "=?"; String[] whereArgs = {name}; db.update(TABLE_NAME, values, whereClause, whereArgs); db.close(); } } ``` 你可以使用以上代码作为参考,根据自己的需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值