Android JetPack 框架库之Room数据库


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

Room数据库

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

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

使用方法

  1. 框架的引入
    implementation “android.arch.persistence.room:runtime:1.1.1”
    kapt “android.arch.persistence.room:compiler:1.1.1”

  2. 构建数据库对象
    Room.databaseBuilder(sContext, AdsDatabase.class, "ads_database.db") .addCallback(new Callback) .addMigrations(new Migration(1, 2) ) .allowMainThreadQueries() .build();

  3. 配置实体
    @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;
    }
    `

  4. 自定义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);
    }

  5. 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类

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android RoomAndroid Jetpack的一个持久性,用于在SQLite数据库上提供抽象层。它简化了与数据库的交互,并提供了一种更健壮和类型安全的方式来处理数据。 以下是使用Android Room框架的一些步骤: 1. 添加依赖项:在项目的build.gradle文件添加以下依赖项: ```groovy dependencies { implementation "androidx.room:room-runtime:2.2.5" annotationProcessor "androidx.room:room-compiler:2.2.5" } ``` 2. 创建实体类:使用`@Entity`注解创建一个实体类,该类将映射到数据库的表。可以使用`@PrimaryKey`注解指定主键,使用`@ColumnInfo`注解指定列名等。 ```java @Entity(tableName = "users") public class User { @PrimaryKey public int id; @ColumnInfo(name = "name") public String name; // 其他属性和方法... } ``` 3. 创建DAO接口:使用`@Dao`注解创建一个数据访问对象(DAO)接口,该接口定义了对数据库进行操作的方法。可以使用`@Query`注解执行自定义查询,使用`@Insert`注解插入数据,使用`@Update`注解更新数据等。 ```java @Dao public interface UserDao { @Query("SELECT * FROM users") List<User> getAllUsers(); @Insert void insertUser(User user); // 其他方法... } ``` 4. 创建数据库使用`@Database`注解创建一个抽象类,该类扩展自`RoomDatabase`,并定义了数据库的版本号和包含的实体类。可以使用`getInstance()`方法获取数据库的实例。 ```java @Database(entities = {User.class}, version = 1) public abstract class AppDatabase extends RoomDatabase { public abstract UserDao userDao(); // 其他方法... } ``` 5. 初始化数据库:在应用程序的入口点或需要访问数据库的地方,使用以下代码初始化数据库: ```java AppDatabase db = Room.databaseBuilder(getApplicationContext(), AppDatabase.class, "my-database").build(); ``` 6. 执行数据库操作:通过DAO接口的方法执行数据库操作。例如,插入一个用户: ```java User user = new User(); user.id = 1; user.name = "John"; db.userDao().insertUser(user); ``` 这样,你就可以使用Android Room框架来管理和操作数据库了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值