Android Room数据库使用(1),2024京东Android面试真题

正文

===============================================================

Google既然在JitPack中推出了Room,那就说明这个库确实有一定的优势。

Room其实和Retrofit差不多,Room在开发阶段通过注解的方式标记相关功能,编译时自动生成响应的impl实现类。

一、添加依赖


首先创建一个Android项目,命名为RoomDemo,我的AS是4.2.1。

在这里插入图片描述

然后打开app下的build.gradle。在dependencies{}闭包中添加如下依赖:

//room

def room_version = “2.3.0”

implementation “androidx.room:room-runtime:$room_version”

annotationProcessor “androidx.room:room-compiler:$room_version”

这里有两个库一个是依赖库,一个是注解处理器库。2.3.0表示room最新的依赖库版本。

在这里插入图片描述

点击Sync进行同步一下。

二、注解使用


注解使用,Room使用很简单的,这里有三个基本的使用注解,@Database、@Entity、@Dao。分别对于数据库、表、表的具体操作(增删改查)。

例如创建一个数据表User。先创建包名,在com.llw.roomdemo下创建一个db包,db下创建bean包,bean包下创建User类。

@Entity

public class User {

@PrimaryKey(autoGenerate = true)

@NonNull

public int id;

@ColumnInfo(name = “user_name”, defaultValue = “”)

public String userName;

@ColumnInfo(name = “user_age”)

public int userAge;

@ColumnInfo(name = “nick_name”)

public String nickName;

@ColumnInfo(name = “address”)

public String address;

public User(String userName, int userAge, String nickName, String address) {

this.id = id;

this.userName = userName;

this.userAge = userAge;

this.nickName = nickName;

this.address = address;

}

}

这个类很平常,主要是注解的说明,这个@Entity就是表示数据库中的表,User类对应就是User表,@PrimaryKey表示主键,这里是id,autoGenerate = true 是自增,@NonNull表示不为空。 @ColumnInfo表示表中的列名,name = "user_name"表示列名的值。

Room是对象关系映射型数据库,所以你可以不用写这个@ColumnInfo注解,写它主要是为了设置列名,不写则使用变量名做为列名。

假设我一个表中有30个字段,实际上用到的只有5个,那么另外25个就不需要进行创建了,则使用@Ignore注解进行忽略。

例如这样:

@Ignore

@ColumnInfo(name = “address”)

public String address;

下面在db包下新建一个dao包,创建UserDao,里面的代码如下:

@Dao

public interface UserDao {

/**

  • 增加

  • @param users 用户

*/

@Insert(onConflict = OnConflictStrategy.REPLACE)

void insertUser(User… users);

/**

  • 查询所有用户

  • @return 用户列表

*/

@Query(“SELECT * FROM user”)

List queryAll();

/**

  • 按用户名查询

  • @param userName 用户名

  • @return 用户

*/

@Query(“SELECT * FROM user WHERE user_name LIKE :userName LIMIT 1”)

User findByName(String userName);

/**

  • 修改

  • @param user 根据用户进行修改

*/

@Update

void update(User user);

/**

  • 删除

  • @param user 根据用户进行删除

*/

@Delete

void delete(User user);

}

UserDao是一个接口,主要是定义了一些方法,通过注解在编译的时候会生成实现类。

下面是数据库的创建,在db包下新建一个MyDatabase类,继承RoomDatabase,代码如下:

@Database(entities = {User.class}, version = 1, exportSchema = false)

public abstract class MyDatabase extends RoomDatabase {

public abstract UserDao userDao();

}

这里的@Database注解表示这个类是用来操作数据库的,entities = {User.class}表示当前数据库中的表,只有一个User表,多的表用应用逗号隔开。version = 1表示数据库的版本,可以做数据库的升级操作。

注意这是一个抽象类,在编译时Room会帮助构建实现类。

现在运行一下,手机或者模拟器都可以。然后什么都不用去做。

在这里插入图片描述

可以查看到,MyDatabase和UserDao的实现类都自动生成了。

三、表操作


表操作无非就是那么几个,增删改查,但是为了更直观的显示结果,需要对UI做一些改动。

在工程的build.gradle中增加repositories闭包中增加jitpack库。

maven { url “https://jitpack.io” }

在这里插入图片描述

然后在app的build.gradle中的dependencies{}比包中增加

implementation ‘com.github.CymChad:BaseRecyclerViewAdapterHelper:3.0.4’

1. 修改布局

Sync一下,下面修改一下页面的布局文件activity_main.xml。

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”

xmlns:app=“http://schemas.android.com/apk/res-auto”

xmlns:tools=“http://schemas.android.com/tools”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:orientation=“vertical”

tools:context=“.MainActivity”>

<Button

android:id=“@+id/btn_add”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:text=“Add”

app:layout_constraintEnd_toEndOf=“parent”

app:layout_constraintStart_toStartOf=“parent”

app:layout_constraintTop_toTopOf=“parent” />

<Button

android:id=“@+id/btn_delete”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:text=“Delete” />

<Button

android:id=“@+id/btn_update”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:text=“Update” />

<Button

android:id=“@+id/btn_query”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:text=“Query” />

<androidx.recyclerview.widget.RecyclerView

android:id=“@+id/rv”

android:layout_width=“match_parent”

android:layout_height=“match_parent” />

这里就是四个按钮和一个列表,当操作按钮时列表数据更新。下面创建列表的item布局。

在layout下新建一个item_rv.xml布局,代码如下:

<?xml version="1.0" encoding="utf-8"?>

<androidx.constraintlayout.widget.ConstraintLayout xmlns:android=“http://schemas.android.com/apk/res/android”

xmlns:app=“http://schemas.android.com/apk/res-auto”

xmlns:tools=“http://schemas.android.com/tools”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”>

<TextView

android:id=“@+id/tv_id”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:padding=“10dp”

android:text=“Id”

android:textColor=“@color/black”

app:layout_constraintStart_toStartOf=“parent”

app:layout_constraintTop_toTopOf=“parent” />

<TextView

android:id=“@+id/tv_name”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:padding=“10dp”

android:text=“name”

android:textColor=“@color/black”

app:layout_constraintStart_toEndOf=“@+id/tv_id”

app:layout_constraintTop_toTopOf=“parent” />

<TextView

android:id=“@+id/tv_age”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:padding=“10dp”

android:text=“age”

android:textColor=“@color/black”

app:layout_constraintStart_toEndOf=“@+id/tv_name”

app:layout_constraintTop_toTopOf=“parent” />

<TextView

android:id=“@+id/tv_nickname”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:padding=“10dp”

android:text=“nickname”

android:textColor=“@color/black”

app:layout_constraintStart_toEndOf=“@+id/tv_age”

app:layout_constraintTop_toTopOf=“parent” />

<TextView

android:id=“@+id/tv_address”

android:layout_width=“0dp”

android:layout_height=“wrap_content”

android:ellipsize=“end”

android:padding=“10dp”

android:text=“address”

android:textColor=“@color/black”

app:layout_constraintEnd_toEndOf=“parent”

app:layout_constraintStart_toEndOf=“@+id/tv_nickname”

app:layout_constraintTop_toTopOf=“parent” />

<View

android:id=“@+id/view”

android:layout_width=“wrap_content”

android:layout_height=“1dp”

android:background=“#E1DFDF”

app:layout_constraintEnd_toEndOf=“parent”

app:layout_constraintHorizontal_bias=“0.0”

app:layout_constraintStart_toStartOf=“parent”

app:layout_constraintTop_toBottomOf=“@+id/tv_nickname” />

</androidx.constraintlayout.widget.ConstraintLayout>

在com.llw.roomdemo下新建一个adapter包,包下新建UserAdapter类,作为列表数据的适配器。代码如下:

2. 列表适配器

public class UserAdapter extends BaseQuickAdapter<User, BaseViewHolder> {

public UserAdapter(int layoutResId, @Nullable List data) {

super(layoutResId, data);

}

@Override

protected void convert(@NotNull BaseViewHolder holder, User user) {

holder.setText(R.id.tv_id, user.id)

.setText(R.id.tv_name, user.userName)

.setText(R.id.tv_age, user.userAge)

.setText(R.id.tv_nickname, user.nickName)

.setText(R.id.tv_address, user.address);

}

}

3. 页面初始化

现在回到MainActivity,页面初始化,先声明两个变量

public static final String TAG = MainActivity.class.getSimpleName();

private MyDatabase db;

private List mList = new ArrayList<>();

private UserAdapter mAdapter;

然后新建一个initView方法,完成对页面控件的初始化,代码如下:

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

针对Android程序员,我这边给大家整理了一些资料,包括不限于高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter等全方面的Android进阶实践技术;希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!

往期Android高级架构资料、源码、笔记、视频。高级UI、性能优化、架构师课程、混合式开发(ReactNative+Weex)全方面的Android进阶实践技术,群内还有技术大牛一起讨论交流解决问题。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

d开发知识点,真正体系化!**

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

针对Android程序员,我这边给大家整理了一些资料,包括不限于高级UI、性能优化、架构师课程、NDK、混合式开发(ReactNative+Weex)微信小程序、Flutter等全方面的Android进阶实践技术;希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!

往期Android高级架构资料、源码、笔记、视频。高级UI、性能优化、架构师课程、混合式开发(ReactNative+Weex)全方面的Android进阶实践技术,群内还有技术大牛一起讨论交流解决问题。

[外链图片转存中…(img-dTdtDEJi-1712342142594)]

[外链图片转存中…(img-yKSGLaTk-1712342142595)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 17
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值