Androidroom清空表,AndroidRoom实现简单的增删改查(⼀)⼤丈夫⽣于天地间,不识其主⽽事之,是⽆智也!今⽇受死,夫何⾜惜!——⽥丰
以前我们在开始学习Android开发的时候,⾸选接触的就是SQLITE数据库,有后来的greenDao数据库、realm数据等。可以查看greenDao官⽹⽇志信息,从greenDao第⼀个版本到最后更新的时间2017-04-05。realm数据库从第⼀个版本到最后⼀个版本是2019年12⽉17⽇。为什么我要在做开发要了解三⽅库的更新时间呢??开发者也要跟上技术时代的节奏,尽量⽤最新的东西,便于我们在⼯作中更好的去解决问题。今天我要提及的是在SQLite的基础上建⽴抽象层的Room框架,Room不是数据库,只是对Sqlie做了⼀个改造,所以呢我们要把概念性的东西弄明⽩
⼀、Room 官⽹介绍:官⽹强烈建议使⽤Room
Room 在 SQLite 上提供了⼀个抽象层,以便在充分利⽤ SQLite 的强⼤功能的同时,能够流畅地访问数据库。
处理⼤量结构化数据的应⽤可极⼤地受益于在本地保留这些数据。最常见的⽤例是缓存相关数据。这样,当设备⽆法访问⽹络时,⽤户仍可在离线状态下浏览相应内容。设备之后重新连接到⽹络后,⽤户发起的所有内容更改都会同步到服务器。
Sqlite保持数据。
⼆、依赖声明:
dependencies {
def room_version = "2.2.2"
implementation ":room-runtime:$room_version"
annotationProcessor ":room-compiler:$room_version" // For Kotlin use
kapt instead of annotationProcessor
}
三、Room 架构
Data Access Objects:数据访问集
Persist changes back to db:数据持久化后返回到数据库
Get Entities from db:从数据库获取实体类
get/set field values:获取字段的值
Dao:包含⽤于访问数据库的⽅法
四、使⽤Room:
1、创建实体类User,实体类名可作为查询时⽤的表名。
Entity;
PrimaryKey;
@Entity
public class User {
@PrimaryKey
public int userId;//⽤户Id
public String userName;//⽤户姓名
public String userAge;//⽤户年龄
}
2、创建数据访问接⼝(接⼝⾥⾯包含增删改查⽅法)
接⼝定义标明注解@Dao;插⼊数据标明@Insert注解;修改数据标明@update;删除数据标明@Delete注解;查询标明@Query注解;Dao;
Delete;
Insert;
Query;
Update;
ity.User;
import java.util.List;
@Dao
public interface UserDao {
//插⼊
@Insert
void users);
@Insert
void addUser(User user);
//修改
@Update
void updateUser(User user);
//删除
@Delete
void deleteUser(User user);
//获取User
@Query("SELECT * FROM user WHERE userName=:userName")
User getUser(String userName);
//查询
@Query("SELECT * FROM User")
ListgetUsers();
}
3、创建继承RoomDatabase抽象类的抽象类,我这⾥命名为MyAppDatabase;entities包含与数据库关联的实体类列表,version是是数据库版本号。
Database;
RoomDatabase;
ity.User;
@Database(entities = {User.class}, version = 1)
public abstract class MyAppDatabase extends RoomDatabase {
public abstract UserDao userDao();
}
4、创建User管理类,进⾏增加、删除、修改、查询⽤户信息:
官⽅原话提⽰:如果您的应⽤在单个进程中运⾏,则在实例化 AppDatabase 对象时应遵循单例设计模式。每个 RoomDatabase 实例的成本相当⾼,⽽您⼏乎不需要在单个进程中访问多个实例。
t.Context;
简易安卓app开发Room;
ity.User;
import java.util.List;
public class UserManager {
private static MyAppDatabase mDb;
public static MyAppDatabase getIntance(Context context) {
if (mDb == null) {
mDb = Room.databaseBuilder(context,
MyAppDatabase.class,
"user.db").build();
}
return mDb;
}
//新增
public static synchronized void addUser(Context context, User user) {
getIntance(context).userDao().addUser(user);
}
//查询
public static synchronized User getUser(Context context, String userName) {
return getIntance(context).userDao().getUser(userName);
}
//删除
public static synchronized void deleteUser(Context context, User user) {
getIntance(context).userDao().deleteUser(user);
}
/
/修改
public static synchronized void updateUser(Context context, User user) {
getIntance(context).userDao().updateUser(user);
}
//获取⽤户信息
public static synchronized ListgetUsers(Context context) {
return getIntance(context).userDao().getUsers();
}
}
5、测试:
⾸选我们调⽤插⼊数据,报错了。。。⼤概意思就是不允许在主线程上访问数据库,会导致UI卡死:
官⽅⽂档原话:
User管理类的代码变更如下:
private static MyAppDatabase mDb;
public static MyAppDatabase getIntance(Context context) {
if (mDb == null) {
mDb = Room.databaseBuilder(context,
MyAppDatabase.class,
"user.db")
.allowMainThreadQueries()
.build();
}
return mDb;
}
再⼀次通过我的案例的界⾯进⾏操作,先后操作增加⽤户信息、查询⽤户信息、删除⽤户信息、查询⽤户信息:⽇志输出信息:I/System.out: 姓名_0
6、SQLScout插件查看数据内容:
先下载SQLScout插件(格式ZIP),将插件安装到Android Studio上。
通过Android Studio菜单栏View 导航到 Tool Windows,到Device File Explorer。
在data/data/应⽤包名/database⽬录下到数据库:
导航到Sqlite Explorer 可以查看db数据库数据:
案例下载地址
SQLScout 插件

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。