前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android利用LitePal操作数据库存取图片

Android利用LitePal操作数据库存取图片

作者头像
砸漏
发布2020-10-22 10:29:00
5100
发布2020-10-22 10:29:00
举报
文章被收录于专栏:恩蓝脚本

Android数据库中存取图片通常使用两种方式,一种是保存图片所在路径,二是将图片以二进制的形式存储(sqlite3支持BLOB数据类型)。对于两种方法的使用,好像第二种方法不如第一种方法更受程序员欢迎,他们认为,在很多数据库语言里,处理大字段都是不容易的,像图片这样的文件放在数据库里会有问题:对数据库的读写速度永远赶不上文件系统的处理速度,使数据库变得巨大;但也有很多人认为像图片这样的数据存放在数据库中也有好处:易于备份,且备份速度绝对比备份文件快,比较容易数据迁移等等。其实这两种方法都有优缺点,具体使用哪种方法要视情况而定。个人倾向于使用数据库存取图片,因为个人认为存到数据库里的数据不会因外部数据的变化而丢失改变,比如你拍照获得一张图片,如果是将路径存到数据库,当这张照片被删除之后,下次读取数据库就得不到想要的结果了。接下来详细介绍数据库存取图片的方法:

1、把图片转换为字节

代码语言:javascript
复制
private byte[]img(Bitmap bitmap){ 
    ByteArrayOutputStream baos = new ByteArrayOutputStream(); 
    bitmap.compress(Bitmap.CompressFormat.PNG, 100, baos); 
    return baos.toByteArray(); 
  } 

2、把图片存储到数据库

假设获取的图片为bitmap,数据库有一张User表,存储的属性为byte[]headshot

代码语言:javascript
复制
public class User extends DataSupport { 
 
private byte[] headshot;//头像 
 
public User(){ 
super(); 
} 
 
public User(byte[]headshot){ 
super(); 
this.headshot=headshot; 
} 
public byte[] getHeadshot() { 
    return headshot; 
  } 
 
  public void setHeadshot(byte[] headshot) { 
    this.headshot = headshot; 
  } 
} 

对图片进行保存

代码语言:javascript
复制
//获取到图片 
Bitmap headShot=BitmapFactory.decodeFile(imagePath); 
//把图片转换字节流 
byte[]images=img(headShot); 
//找到用户 
User users=DataSupport.findFirst(User.class); 
//保存 
users.setHeadshot(images); 
users.save(); 

4、获取图片

代码语言:javascript
复制
User mUser=DataSupport.findFrist(User.class); 
byte[]images=mUser.getHeadshot(); 
Bitmap bitmap=BitmapFactory.decodeByteArray(images,0,images.length); 

好了,到此完成对数据库存取图片。

以上就是本文的全部内容,希望对大家的学习有所帮助。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档