Android Room数据库使用

  • 按用户名查询

  • @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方法,完成对页面控件的初始化,代码如下:

/**

  • 初始化

*/

private void initView() {

findViewById(R.id.btn_add).setOnClickListener(this);

findViewById(R.id.btn_delete).setOnClickListener(this);

findViewById(R.id.btn_update).setOnClickListener(this);

findViewById(R.id.btn_query).setOnClickListener(this);

//列表

RecyclerView rv = findViewById(R.id.rv);

mAdapter = new UserAdapter(R.layout.item_rv,mList);

rv.setLayoutManager(new LinearLayoutManager(this));

rv.setAdapter(mAdapter);

//数据库

db = MyApplication.getDb();

}

这个方法中首先是对按钮的点击设置监听回调,其次是对列表和适配器进行数据的绑定,页面的MainActivity需要实现View.OnClickListener接口。

在这里插入图片描述

重写里面的onClick方法。等会的数据库表操作就是通过这里的点击事件进行触发。

@Override

public void onClick(View v) {

switch (v.getId()){

case R.id.btn_add:

break;

case R.id.btn_delete:

break;

case R.id.btn_update:

break;

case R.id.btn_query:

break;

default:break;

}

}

在onCreate方法中调用这个initView方法。

在这里插入图片描述

initDB方法:

/**

  • 初始化数据库

*/

private void initDB() {

//本地持久化数据库

db = Room.databaseBuilder(getApplicationContext(), MyDatabase.class, “DemoDB”)

//是否允许在主线程上操作数据库,默认false。

.allowMainThreadQueries()

//数据库创建和打开的事件会回调到这里,可以再次操作数据库

.addCallback(new CallBack())

.build();

}

CallBack

static class CallBack extends RoomDatabase.Callback {

@Override

public void onCreate(@NonNull SupportSQLiteDatabase db) {

super.onCreate(db);

Log.d(TAG, “db create”);

}

@Override

public void onOpen(@NonNull SupportSQLiteDatabase db) {

super.onOpen(db);

Log.d(TAG, “db open”);

}

}

下面就可以进行数据库表的操作了,增删改查。

[](https://llw-study.blog.csdn.net/arti

cle/details/119357503)4. 增删改查

当前数据表中还没有任何数据,因此需要先增加数据。然后查询,删除后查询,修改后查询,这样增删改查就都涉及到了。

方法如下:

/**

  • 增加用户

*/

private void addUser() {

runOnUiThread(() -> {

db.userDao().insertUser(new User(“张三”, 20, “张大炮”, “北京八宝山4号墓地”),

new User(“李四”, 60, “尼古拉斯.凯奇”, “美国佛罗里达州”),

new User(“王五”, 70, “爱新觉罗.爱国”, “北京故宫乾清宫西北方向角落”),

new User(“赵六”, 30, “叶赫那拉.啦啦啦”, “北京前门外前门大街皮条胡同”));

Toast.makeText(MainActivity.this,“增加成功”,Toast.LENGTH_SHORT).show();

});

}

/**

  • 删除用户

*/

private void deleteUser() {

runOnUiThread(() -> {

User user = db.userDao().findByName(“张三”);

if (user == null) return;

db.userDao().delete(user);

Toast.makeText(MainActivity.this, “删除成功”, Toast.LENGTH_SHORT).show();

});

}

/**

  • 修改用户

*/

private void updateUser() {

runOnUiThread(() -> {

User user = db.userDao().findByName(“李四”);

if (user == null) return;

user.setUserName(“赵四”);

user.setUserAge(10);

user.setNickName(“尼古拉斯.赵四”);

user.setAddress(“中国东北”);

db.userDao().update(user);

Toast.makeText(MainActivity.this, “修改成功”, Toast.LENGTH_SHORT).show();

});

}

/**

  • 查询所有用户

*/

private void queryAll() {

runOnUiThread(() -> {

mList.clear();

mList.addAll(db.userDao().queryAll());

mAdapter.notifyDataSetChanged();

});

}

在这里插入图片描述

运行的效果图如下:

最后

小编这些年深知大多数初中级Android工程师,想要提升自己,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

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

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人

都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

资料⬅专栏获取

/**

  • 查询所有用户

*/

private void queryAll() {

runOnUiThread(() -> {

mList.clear();

mList.addAll(db.userDao().queryAll());

mAdapter.notifyDataSetChanged();

});

}

在这里插入图片描述

运行的效果图如下:

最后

小编这些年深知大多数初中级Android工程师,想要提升自己,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助

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

[外链图片转存中…(img-U3XETgxK-1718820195592)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人

都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

资料⬅专栏获取

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值