这里写自定义目录标题

Room数据库使用方法接下来我们要做一个核心的操作,就是对项目进行build。如果项目执行成功,将会对Database和Dao类生成新的Impl类

JetPack是2018年谷歌大会推出的一个android开发工具库,目前JetPack主要封装的功能包含基础框架、应用架构、应用行为和UI界面四个方面。

今天来介绍一下jetpack中的Room数据库

Room数据库

Android的数据库是基于SQLite数据库的简单封装;用户需要继承SQLiteOpenHelper类实现数据的增删改查;手动转换关系型数据到Java对象数据的操作繁琐而且很容易产生大量的重复代码。目前市面上有不少第三方开源的ORM库;不过这些库的体积庞大;有些还使用反射容易造成性能问题。

Room ORM框架基于注解和APT在编译时生成代码;用户只需要简单配置实体对象就能够正确生成数据库表;所有数据库操作都只需要用户提供对应的SQL语句;查询工作完全由框架生成模板代码。ROOM框架封装后的数据库逻辑完全是面向对象的实现方式;能够轻松的集成到Android开发项目中。

使用方法

框架的引入 : implementation “android.arch.persistence.room:runtime:1.1.1” kapt “android.arch.persistence.room:compiler:1.1.1” 构建数据库对象 : Room.databaseBuilder(sContext, AdsDatabase.class, "ads_database.db") .addCallback(new Callback) .addMigrations(new Migration(1, 2) ) .allowMainThreadQueries() .build(); 配置实体 : @Entity(tableName = “tb_download”) public class DownloadEntity { @PrimaryKey(autoGenerate = true) private int id; private String url; private long startTime; private long downloadTime; private int status; private int loadType; private String description; } ` 自定义Dao对象 : @Dao public interface DownloadDao { @Insert void insert(DownloadEntity entity); @Query(“delete from tb_download”) void deleteAll(); @Query(“select * from tb_download where status in (:status)”) List queryByStatus(int[] status); } DB类增加注解实体,添加Dao返回接口: @Database(entities = { DownloadEntity.class, MovieEntity.class }, version = 3) public abstract class AdsDatabase extends RoomDatabase { public abstract DownloadDao getDownloadDao(); public abstract MovieDao getMovieDao(); }

接下来我们要做一个核心的操作,就是对项目进行build。如果项目执行成功,将会对Database和Dao类生成新的Impl类

好文链接

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: