欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android使用Room操作數(shù)據(jù)庫流程詳解

 更新時間:2022年11月17日 09:59:52   作者:Flynn_MIMD  
谷歌推薦使用Room操作數(shù)據(jù)庫,Room在 SQLite 上提供了一個抽象層,在充分利用 SQLite強(qiáng)大功能的同時,能夠流暢地訪問數(shù)據(jù)庫

Room的三個主要組件:

  • 數(shù)據(jù)庫類,用于保存數(shù)據(jù)庫并作為應(yīng)用持久性數(shù)據(jù)底層連接的主要訪問點(diǎn)。
  • 數(shù)據(jù)實(shí)體,@Entity,表示數(shù)據(jù)庫中的表。
  • 數(shù)據(jù)訪問對象 (DAO),@Dao,提供查詢、更新、插入和刪除數(shù)據(jù)的方法。

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)建實(shí)體類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實(shí)體類,users表的名稱,不加默認(rèn)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);
}

增,刪,改:將實(shí)例與表的主鍵進(jìn)行匹配

查詢結(jié)果將自動映射到對應(yīng)類型的字段,若未映射將報警告

3. 數(shù)據(jù)庫

抽象類AppDatabase 定義數(shù)據(jù)庫配置,并作為應(yīng)用對持久性數(shù)據(jù)的主要訪問點(diǎn),擴(kuò)展了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é)約獲取數(shù)據(jù)庫的時間和資源,采取單例模式

簡單實(shí)現(xiàn):

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;
    }
}

調(diào)用

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();
    }
}

路過的大佬們有更好的單例實(shí)現(xiàn)請告訴我一下,

到此這篇關(guān)于Android使用Room操作數(shù)據(jù)庫流程詳解的文章就介紹到這了,更多相關(guān)Android Room內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論