Android使用Room操作數據庫流程詳解
Room的三個主要組件:
- 數據庫類,用于保存數據庫并作為應用持久性數據底層連接的主要訪問點。
- 數據實體,@Entity,表示數據庫中的表。
- 數據訪問對象 (DAO),@Dao,提供查詢、更新、插入和刪除數據的方法。
build.gradle添加
dependencies {
def room_version = "2.4.3"implementation "android.arch.persistence.room:runtime:$room_version"
annotationProcessor "android.arch.persistence.room:compiler:$room_version"implementation "android.arch.persistence.room:rxjava2:$room_version"
testImplementation "android.arch.persistence.room:testing:$room_version"
}
1. 創(chuàng)建實體類User
@Entity(tableName = "users") public class User { @PrimaryKey public int uid; @ColumnInfo(name = "first_name") public String firstName; @ColumnInfo(name = "last_name") public String lastName; }
@Entity實體類,users表的名稱,不加默認user
@ColumnInfo列名
@PrimaryKey主鍵
2. 創(chuàng)建DAO
@Dao public interface UserDao { @Query("SELECT * FROM user") List<User> getAll(); @Query("SELECT * FROM user WHERE uid IN (:userIds)") List<User> loadAllByIds(int[] userIds); @Query("SELECT * FROM user WHERE first_name LIKE :first AND " + "last_name LIKE :last LIMIT 1") User findByName(String first, String last); @Insert(onConflict = OnConflictStrategy.REPLACE) void insertAll(User... users); @Delete void delete(User user); }
增,刪,改:將實例與表的主鍵進行匹配
查詢結果將自動映射到對應類型的字段,若未映射將報警告
3. 數據庫
抽象類AppDatabase 定義數據庫配置,并作為應用對持久性數據的主要訪問點,擴展了RommDataBase
@Database(entities = {User.class}, version = 1, exportSchema = false) public abstract class AppDataBase extends RoomDatabase { public abstract UserDao userDao(); }
4. 使用
AppDataBase db = Room.databaseBuilder(getApplicationContext(), AppDataBase.class, "database-name").build(); for (int i = 0; i < 10; i++) { User user = new User(); user.uid = i; user.firstName = "Shell" + i; user.lastName = "Hub" + i; db.userDao().insertAll( user); List<User> userList = db.userDao().getAll(); for(User user1 : userList) { Log.d("mip",""+user1.firstName); } }
為了節(jié)約獲取數據庫的時間和資源,采取單例模式
簡單實現:
public class Utils { private static AppDataBase db = null; private static Context context = null; public static AppDataBase getDb(){ if( db == null) { db = Room.databaseBuilder(context, AppDataBase.class, "database-name").build(); } return db; } public static void setContext(Context context){ Utils.context = context; } }
調用
public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Utils.setContext(getApplicationContext()); new Thread(new Runnable() { @Override public void run() { AppDataBase db = Utils.getDb(); for (int i = 0; i < 10; i++) { User user = new User(); user.uid = i; user.firstName = "Shell" + i; user.lastName = "Hub" + i; db.userDao().insertAll( user); List<User> userList = db.userDao().getAll(); for(User user1 : userList) { Log.d("mip",""+user1.firstName); } } } }).start(); } }
路過的大佬們有更好的單例實現請告訴我一下,
到此這篇關于Android使用Room操作數據庫流程詳解的文章就介紹到這了,更多相關Android Room內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Android實現socket通信統(tǒng)一接口的方法
這篇文章主要介紹了Android實現socket通信統(tǒng)一接口?,實現了統(tǒng)一接口之后確實可以使后續(xù)修改實現更加方便,程序結構也更加工程化,需要的朋友可以參考下2021-12-12