【安卓开发】数据库Room框架的学习和使用

简单的轻量级框架,SQL语句不复杂。步骤如下:

添加依赖

dependencies {
    def room_version="2.3.0"
    implementation "androidx.room:room-runtime:$room_version"
    annotationProcessor "androidx.room:room-compiler:$room_version"
}

创建实体类

@Entity //实体类注解
public class Data{
    @PrimaryKey(autoGenerate = true)//主键自动递增
    private int id;
    @ColumnInfo(name="title")//指定列名,不指定的话列名等于变量名
    private String title;
    @ColumnInfo(name="tt")
    private String tt;
}

创建接口

S Q L SQL SQL查询语句,多个条件用 a n d , o r and,or and,or连接

@Dao
public interface DataDao {
    @Insert
    void insertData(Data data);
    @Query("delete from data")
    void deleteAll();
    @Query("select * from data")
    List<Data> findAll();
    @Query("delete from data where id =:pos")
    void deleteById(int pos);
    @Query("select * from data where tt=:t1 and title=:t2")
    List<Data> find_by(String t1,String t2);
}

创建数据库

单例模式

@Database(entities = {Data.class,Person.class},version = 1,exportSchema = false)
public abstract class NDatabase extends RoomDatabase {
    private static NDatabase INSTANCE;
    static public NDatabase getDatabase(Context context){
        if(INSTANCE==null) {
            INSTANCE= Room.databaseBuilder(context,NDatabase.class,"n_database")
                    .allowMainThreadQueries().build();
            //数据库名 n_database
            //表名 Data和Person
        }
        return INSTANCE;
    }
    public abstract DataDao getDataDao();
    public abstract PersonDao getPersonDao();
}

获取数据库实例和接口

private NDatabase nDatabase;
private DataDao dataDao;
nDatabase=NDatabase.getDatabase(this);
dataDao=nDatabase.getDataDao();

增删改查

调用实例后的数据库对象里dao接口的对应方法,比如

List<Data> t=dataDao.findAll();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

豆沙睡不醒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值