• 基础复习——利用Room简化数据库操作——重点


    使用数据库帮助器编码的时候,开发者每次都得手工实现以下代码逻辑:

    (1)重写数据库帮助器的onCreate方法,添加该表的建表语句;(2)在插入记录之时,必须将数据实例的属性值逐一赋给该表的各字段;(3)在查询记录之时,必须遍历结果集游标,把各字段值逐一赋给数据实例;(4)每次读写操作之前,都要先开启数据库连接;读写操作之后,又要关闭数据库连接;

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

    实体类  BookInfo:

    1. package com.example.myapplication.entity;
    2. import androidx.annotation.NonNull;
    3. import androidx.room.Entity;
    4. import androidx.room.PrimaryKey;
    5. //书籍信息
    6. @Entity
    7. public class BookInfo
    8. {
    9. @PrimaryKey // 该字段是主键,不能重复
    10. @NonNull // 主键必须是非空字段
    11. private String name; // 书籍名称
    12. private String author; // 作者
    13. private String press; // 出版社
    14. private double price; // 价格
    15. public void setName(String name) {
    16. this.name = name;
    17. }
    18. public String getName() {
    19. return this.name;
    20. }
    21. public void setAuthor(String author) {
    22. this.author = author;
    23. }
    24. public String getAuthor() {
    25. return this.author;
    26. }
    27. public void setPress(String press) {
    28. this.press = press;
    29. }
    30. public String getPress() {
    31. return this.press;
    32. }
    33. public void setPrice(double price) {
    34. this.price = price;
    35. }
    36. public double getPrice() {
    37. return this.price;
    38. }
    39. }

    持久化类BookDao:

    1. package com.example.myapplication.dao;
    2. import androidx.room.Dao;
    3. import androidx.room.Delete;
    4. import androidx.room.Insert;
    5. import androidx.room.OnConflictStrategy;
    6. import androidx.room.Query;
    7. import androidx.room.Update;
    8. import com.example.myapplication.entity.BookInfo;
    9. import java.util.List;
    10. @Dao
    11. public interface BookDao
    12. {
    13. @Query("SELECT * FROM BookInfo") // 设置查询语句
    14. List queryAllBook(); // 加载所有书籍信息
    15. @Query("SELECT * FROM BookInfo WHERE name = :name") // 设置带条件的查询语句
    16. BookInfo queryBookByName(String name); // 根据名字加载书籍
    17. @Insert(onConflict = OnConflictStrategy.REPLACE) // 记录重复时替换原记录
    18. void insertOneBook(BookInfo book); // 插入一条书籍信息
    19. @Insert
    20. void insertBookList(List bookList); // 插入多条书籍信息
    21. @Update(onConflict = OnConflictStrategy.REPLACE)// 出现重复记录时替换原记录
    22. int updateBook(BookInfo book); // 更新书籍信息
    23. @Delete
    24. void deleteBook(BookInfo book); // 删除书籍信息
    25. @Query("DELETE FROM BookInfo WHERE 1=1") // 设置删除语句
    26. void deleteAllBook(); // 删除所有书籍信息
    27. }

    数据库类 bookDatabase:

    1. package com.example.myapplication.database;
    2. import androidx.room.Database;
    3. import androidx.room.RoomDatabase;
    4. import com.example.myapplication.dao.BookDao;
    5. import com.example.myapplication.entity.BookInfo;
    6. //entities表示该数据库有哪些表,version表示数据库的版本号
    7. //exportSchema表示是否导出数据库信息的json串,建议设为false,若设为true还需指定json文件的保存路径
    8. @Database(entities = {BookInfo.class},version = 1, exportSchema = false)
    9. public abstract class BookDatabase extends RoomDatabase
    10. {
    11. // 获取该数据库中某张表的持久化对象
    12. public abstract BookDao bookDao();
    13. }

    在自定义的Application类中声明书籍数据库的唯一实例:

    1. package com.example.myapplication;
    2. import android.app.Application;
    3. import android.util.Log;
    4. import androidx.room.Room;
    5. import com.example.myapplication.database.BookDatabase;
    6. import java.util.HashMap;
    7. public class MainApplication extends Application
    8. {
    9. private final static String TAG = "MainApplication";
    10. private static MainApplication mApp; // 声明一个当前应用的静态实例
    11. // 声明一个公共的信息映射对象,可当作全局变量使用
    12. public HashMap<String, String> infoMap = new HashMap<String, String>();
    13. public static int goodsCount = 0;
    14. private BookDatabase bookDatabase; // 声明一个书籍数据库对象
    15. // 利用单例模式获取当前应用的唯一实例
    16. public static MainApplication getInstance()
    17. {
    18. return mApp;
    19. }
    20. @Override
    21. public void onCreate()
    22. {
    23. super.onCreate();
    24. Log.d(TAG, "onCreate");
    25. mApp = this; // 在打开应用时对静态的应用实例赋值
    26. // 构建书籍数据库的实例
    27. bookDatabase = Room.databaseBuilder(mApp, BookDatabase.class,"BookInfo")
    28. .addMigrations() // 允许迁移数据库(发生数据库变更时,Room默认删除原数据库再创建新数据库。如此一来原来的记录会丢失,故而要改为迁移方式以便保存原有记录)
    29. .allowMainThreadQueries() // 允许在主线程中操作数据库(Room默认不能在主线程中操作数据库)
    30. .build();
    31. }
    32. @Override
    33. public void onTerminate()
    34. {
    35. super.onTerminate();
    36. Log.d(TAG, "onTerminate");
    37. }
    38. // 获取书籍数据库的实例
    39. public BookDatabase getBookDB()
    40. {
    41. return bookDatabase;
    42. }
    43. }

     

    写布局:

    1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    2. android:layout_width="match_parent"
    3. android:layout_height="match_parent"
    4. android:orientation="vertical"
    5. android:padding="5dp" >
    6. <RelativeLayout
    7. android:layout_width="match_parent"
    8. android:layout_height="40dp" >
    9. <TextView
    10. android:id="@+id/tv_name"
    11. android:layout_width="wrap_content"
    12. android:layout_height="match_parent"
    13. android:gravity="center"
    14. android:text=" 书名:"
    15. android:textColor="@color/black"
    16. android:textSize="17sp" />
    17. <EditText
    18. android:id="@+id/et_name"
    19. android:layout_width="match_parent"
    20. android:layout_height="match_parent"
    21. android:layout_marginBottom="3dp"
    22. android:layout_marginTop="3dp"
    23. android:layout_toRightOf="@+id/tv_name"
    24. android:background="@drawable/editext_selector"
    25. android:gravity="left|center"
    26. android:hint="请输入书籍名称"
    27. android:inputType="text"
    28. android:maxLength="30"
    29. android:textColor="@color/black"
    30. android:textSize="17sp" />
    31. </RelativeLayout>
    32. <RelativeLayout
    33. android:layout_width="match_parent"
    34. android:layout_height="40dp" >
    35. <TextView
    36. android:id="@+id/tv_author"
    37. android:layout_width="wrap_content"
    38. android:layout_height="match_parent"
    39. android:gravity="center"
    40. android:text=" 作者:"
    41. android:textColor="@color/black"
    42. android:textSize="17sp" />
    43. <EditText
    44. android:id="@+id/et_author"
    45. android:layout_width="match_parent"
    46. android:layout_height="match_parent"
    47. android:layout_marginBottom="3dp"
    48. android:layout_marginTop="3dp"
    49. android:layout_toRightOf="@+id/tv_author"
    50. android:background="@drawable/editext_selector"
    51. android:gravity="left|center"
    52. android:hint="请输入作者姓名"
    53. android:inputType="text"
    54. android:maxLength="10"
    55. android:textColor="@color/black"
    56. android:textSize="17sp" />
    57. </RelativeLayout>
    58. <RelativeLayout
    59. android:layout_width="match_parent"
    60. android:layout_height="40dp" >
    61. <TextView
    62. android:id="@+id/tv_press"
    63. android:layout_width="wrap_content"
    64. android:layout_height="match_parent"
    65. android:gravity="center"
    66. android:text="出版社:"
    67. android:textColor="@color/black"
    68. android:textSize="17sp" />
    69. <EditText
    70. android:id="@+id/et_press"
    71. android:layout_width="match_parent"
    72. android:layout_height="match_parent"
    73. android:layout_marginBottom="3dp"
    74. android:layout_marginTop="3dp"
    75. android:layout_toRightOf="@+id/tv_press"
    76. android:background="@drawable/editext_selector"
    77. android:gravity="left|center"
    78. android:hint="请输入出版社名称"
    79. android:inputType="text"
    80. android:maxLength="20"
    81. android:textColor="@color/black"
    82. android:textSize="17sp" />
    83. </RelativeLayout>
    84. <RelativeLayout
    85. android:layout_width="match_parent"
    86. android:layout_height="40dp" >
    87. <TextView
    88. android:id="@+id/tv_price"
    89. android:layout_width="wrap_content"
    90. android:layout_height="match_parent"
    91. android:gravity="center"
    92. android:text=" 价格:"
    93. android:textColor="@color/black"
    94. android:textSize="17sp" />
    95. <EditText
    96. android:id="@+id/et_price"
    97. android:layout_width="match_parent"
    98. android:layout_height="match_parent"
    99. android:layout_marginBottom="3dp"
    100. android:layout_marginTop="3dp"
    101. android:layout_toRightOf="@+id/tv_price"
    102. android:background="@drawable/editext_selector"
    103. android:gravity="left|center"
    104. android:hint="请输入书籍价格"
    105. android:inputType="numberDecimal"
    106. android:maxLength="6"
    107. android:textColor="@color/black"
    108. android:textSize="17sp" />
    109. </RelativeLayout>
    110. <Button
    111. android:id="@+id/btn_save"
    112. android:layout_width="match_parent"
    113. android:layout_height="wrap_content"
    114. android:text="保存到数据库"
    115. android:textColor="@color/black"
    116. android:textSize="17sp" />
    117. </LinearLayout>

    写代码:

    1. package com.example.myapplication;
    2. import androidx.appcompat.app.AppCompatActivity;
    3. import android.os.Bundle;
    4. import android.text.TextUtils;
    5. import android.view.View;
    6. import android.widget.EditText;
    7. import com.example.myapplication.dao.BookDao;
    8. import com.example.myapplication.entity.BookInfo;
    9. public class RoomWriteActivity extends AppCompatActivity implements View.OnClickListener {
    10. private EditText et_name;
    11. private EditText et_author;
    12. private EditText et_press;
    13. private EditText et_price;
    14. private BookDao bookDao; // 声明一个书籍的持久化对象
    15. @Override
    16. protected void onCreate(Bundle savedInstanceState) {
    17. super.onCreate(savedInstanceState);
    18. setContentView(R.layout.activity_room_write);
    19. et_name = findViewById(R.id.et_name);
    20. et_author = findViewById(R.id.et_author);
    21. et_press = findViewById(R.id.et_press);
    22. et_price = findViewById(R.id.et_price);
    23. findViewById(R.id.btn_save).setOnClickListener(this);
    24. // 从App实例中获取唯一的书籍持久化对象
    25. bookDao = MainApplication.getInstance().getBookDB().bookDao();
    26. }
    27. @Override
    28. public void onClick(View v) {
    29. if (v.getId() == R.id.btn_save) {
    30. String name = et_name.getText().toString();
    31. String author = et_author.getText().toString();
    32. String press = et_press.getText().toString();
    33. String price = et_price.getText().toString();
    34. if (TextUtils.isEmpty(name)) {
    35. ToastUtil.show(this, "请先填写书籍名称");
    36. return;
    37. } else if (TextUtils.isEmpty(author)) {
    38. ToastUtil.show(this, "请先填写作者姓名");
    39. return;
    40. } else if (TextUtils.isEmpty(press)) {
    41. ToastUtil.show(this, "请先填写出版社名称");
    42. return;
    43. } else if (TextUtils.isEmpty(price)) {
    44. ToastUtil.show(this, "请先填写价格");
    45. return;
    46. }
    47. // 以下声明一个书籍信息对象,并填写它的各字段值
    48. BookInfo info = new BookInfo();
    49. info.setName(name);
    50. info.setAuthor(author);
    51. info.setPress(press);
    52. info.setPrice(Double.parseDouble(price));
    53. bookDao.insertOneBook(info); // 往数据库插入一条书籍记录
    54. ToastUtil.show(this, "数据已写入Room数据库");
    55. }
    56. }
    57. }

     

    读布局:

    1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    2. android:layout_width="match_parent"
    3. android:layout_height="match_parent"
    4. android:orientation="vertical" >
    5. <Button
    6. android:id="@+id/btn_delete"
    7. android:layout_width="match_parent"
    8. android:layout_height="wrap_content"
    9. android:text="删除所有记录"
    10. android:textColor="@color/black"
    11. android:textSize="17sp" />
    12. <TextView
    13. android:id="@+id/tv_room"
    14. android:layout_width="match_parent"
    15. android:layout_height="wrap_content"
    16. android:paddingLeft="5dp"
    17. android:textColor="@color/black"
    18. android:textSize="17sp" />
    19. </LinearLayout>

    读代码:

    1. package com.example.myapplication;
    2. import androidx.appcompat.app.AppCompatActivity;
    3. import android.os.Bundle;
    4. import android.view.View;
    5. import android.widget.TextView;
    6. import com.example.myapplication.dao.BookDao;
    7. import com.example.myapplication.entity.BookInfo;
    8. import java.util.List;
    9. public class RoomReadActivity extends AppCompatActivity implements View.OnClickListener
    10. {
    11. private TextView tv_room;
    12. private BookDao bookDao; // 声明一个书籍的持久化对象
    13. @Override
    14. protected void onCreate(Bundle savedInstanceState)
    15. {
    16. super.onCreate(savedInstanceState);
    17. setContentView(R.layout.activity_room_read);
    18. tv_room = findViewById(R.id.tv_room);
    19. findViewById(R.id.btn_delete).setOnClickListener(this);
    20. // 从App实例中获取唯一的书籍持久化对象
    21. bookDao = MainApplication.getInstance().getBookDB().bookDao();
    22. readRoom(); // 读取数据库中的所有书籍记录
    23. }
    24. // 读取数据库中的所有书籍记录
    25. private void readRoom()
    26. {
    27. List<BookInfo> bookList = bookDao.queryAllBook(); // 获取所有书籍记录
    28. String desc = String.format("数据库查询到%d条记录,详情如下:", bookList.size());
    29. for (int i = 0; i < bookList.size(); i++)
    30. {
    31. BookInfo info = bookList.get(i);
    32. desc = String.format("%s\n第%d条记录信息如下:", desc, i + 1);
    33. desc = String.format("%s\n 书名为《%s》", desc, info.getName());
    34. desc = String.format("%s\n 作者为%s", desc, info.getAuthor());
    35. desc = String.format("%s\n 出版社为%s", desc, info.getPress());
    36. desc = String.format("%s\n 价格为%f", desc, info.getPrice());
    37. }
    38. if (bookList.size() <= 0)
    39. {
    40. desc = "数据库查询到的记录为空";
    41. }
    42. tv_room.setText(desc);
    43. }
    44. @Override
    45. public void onClick(View v)
    46. {
    47. if (v.getId() == R.id.btn_delete)
    48. {
    49. bookDao.deleteAllBook(); // 删除所有书籍记录
    50. ToastUtil.show(this, "已删除所有记录");
    51. readRoom(); // 读取数据库中的所有书籍记录
    52. }
    53. }
    54. }

     

     

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

     

     

     

  • 相关阅读:
    js网络请求---fetch和XMLHttpRequest的用法
    网络安全渗透测试实验一
    柔性数组
    你能解释一下Spring AOP(面向切面编程)的概念和用法吗?在Spring中,如何使用事务管理?
    《STL源码剖析》笔记——allocator
    nginx 命令
    【AGV机器人智能取物】企业都能用得起的WMS/RFID系统立体智能仓库
    Elasticsearch上手指南
    CasA:用于点云 3D 目标检测的级联注意力网络
    XS9922A,XS9922B四路模拟高清方案
  • 原文地址:https://blog.csdn.net/m0_61442607/article/details/126441750