Android Sqlite 之 getWritableDatabase()和getReadableDatabase()区别

在Android开发中,如果我们想对sqlite数据库进行一系列的操作,都需要获得一个SQLiteDatabase对象,然后调用它的增删改查方法,官方给我们提供了两种方法来获得我们所需要的对象,getWritableDatabase()和getReadableDatabase(),但是这两种方法有什么不同之处呢?相信很多人没有去研究过吧?下面就给大家讲讲区别:

首先getWritableDatabase()和getReadableDatabase()都返回一个SQLiteDatabase对象,但getWritableDatabase()方法以读写方式打开数据库,一旦数据库的磁盘空间满了,数据库就只能读而不能写,
此时使用getWritableDatabase()打开数据库就会出错。而getReadableDatabase()方法先以读写方式打开数据库,
倘若使用如果数据库的磁盘空间满了,就会打开失败,当打开失败后会继续尝试以只读方式打开数据库.

在实际开发中,我们很少会遇到数据库所在的磁盘空间满了,所以这两种方法都可以使用。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android SQLite可以存储图片,这里提供一种简单的方法。 首先,将图片转换为字节数组,然后将其存储为BLOB类型的数据。以下是一个示例方法,将位图转换为字节数组: ```java public static byte[] getBytesFromBitmap(Bitmap bitmap) { ByteArrayOutputStream stream = new ByteArrayOutputStream(); bitmap.compress(Bitmap.CompressFormat.PNG, 100, stream); return stream.toByteArray(); } ``` 接下来,将字节数组存储到SQLite数据库中。以下是一个示例方法,将字节数组存储到SQLite数据库中: ```java public void insertImage(byte[] imageBytes) { SQLiteDatabase db = this.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("image", imageBytes); db.insert("images", null, values); db.close(); } ``` 最后,从SQLite数据库中检索图像并将其转换回位图。以下是一个示例方法,从SQLite数据库中检索图像并将其转换回位图: ```java public Bitmap getImage(int id) { SQLiteDatabase db = this.getReadableDatabase(); String[] columns = new String[] { "image" }; String whereClause = "id=?"; String[] whereArgs = new String[] { String.valueOf(id) }; Cursor cursor = db.query("images", columns, whereClause, whereArgs, null, null, null); if (cursor.moveToFirst()) { byte[] imageBytes = cursor.getBlob(0); cursor.close(); db.close(); return BitmapFactory.decodeByteArray(imageBytes, 0, imageBytes.length); } cursor.close(); db.close(); return null; } ``` 这些方法应该能够帮助你在Android SQLite中存储和检索图像。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值