Android 操作資料庫的架構——greenDAO的學習

來源:互聯網
上載者:User

Android 操作資料庫的架構——greenDAO的學習
greenDAO的使用

簡介

官網給出如下介紹:


greenDAO是一個對象關係映射(ORM)的架構,能夠提供一個介面通過操作對象的方式去操作關係型資料庫,它能夠讓你操作資料庫時更簡單、更方便。


在使用greenDAO的時候需要建立兩個project,其中一個是java工程,它用來產生特定於您的項目的代碼域(即產生了bean對象和操作資料庫的dao)

核心的classes

DaoMaster:
DaoMaster儲存了資料庫物件和管理DAO類的classes,其提供了一些靜態方法建立和刪除表,內部類OpenHelper和DevOpenHelper 實現了SQLiteOpenHelper並建立資料庫的架構。

DaoSession:
管理所有可用的DAO對象,可以通過getter方法獲得。DaoSession還提供了一些通用的持久性方法比如插入、載入、更新,重新整理和刪除實體。

DAOs:
Data Access Objects,每一個實體類都有對應的greenDAO對象。

Entities:
實體類對象

核心greenDAO類初始化資料庫
helper = new DaoMaster.DevOpenHelper(this, "notes-db", null);db = helper.getWritableDatabase();daoMaster = new DaoMaster(db);daoSession = daoMaster.newSession();noteDao = daoSession.getNoteDao();
主要優點greenDAO 效能遠遠高於同類的 ORMLite,具體測試結果可見官網 greenDAO 支援 protocol buffer(protobuf) 協議資料的直接儲存,如果你通過 protobuf 協議與伺服器互動,將不需要任何的映射。 與 ORMLite 等使用註解方式的 ORM 架構不同,greenDAO 使用「Code generation」的方式,這也是其效能能大幅提升的原因。使用方法1.建立Android project並在main目錄下建立檔案夾java-gen(存放自動產生bean和dao)2.在build.gradle中配置
//buildTypes{}中配置sourceSets {    main {        java.srcDirs = ['src/main/java', 'src/main/java-gen']    }}//dependencies{}中配置compile 'de.greenrobot:greendao:2.1.0'

3.建立java project——greenDAO_java

在build.gradle中添加

compile 'de.greenrobot:greendao-generator:2.1.0'

建立模式對象,並添加實體(表)

public class Generator {    public static void main(String[] args) throws Exception {        int version=1;        String defaultPackage="test.greenDAO.bean";        //建立模式對象,指定版本號碼和自動產生的bean對象的包名        Schema schema=new Schema(version,defaultPackage);        //指定自動產生的dao對象的包名,不指定則都DAO類產生在"test.greenDAO.bean"包中        schema.setDefaultJavaPackageDao("test.greenDAO.dao");        //添加實體        addEntity(schema);        String outDir="D:/adt-bundle-windows-x64/workspace/studio/frame/study_demo/testgreendao/src/main/java-gen";        //調用DaoGenerator().generateAll方法自動產生代碼到之前建立的java-gen目錄下        new DaoGenerator().generateAll(schema,outDir);    }    private static void addEntity(Schema schema) {        //添加一個實體,則會自動產生實體Entity類        Entity entity = schema.addEntity("Entity");        //指定表名,如不指定,表名則為 Entity(即實體類名)        entity.setTableName("student");        //給實體類中添加屬性(即給test表中添加欄位)        entity.addIdProperty().autoincrement();//添加Id,自增長        entity.addStringProperty("name").notNull();//添加String類型的name,不可為空        entity.addIntProperty("age");//添加Int類型的age        entity.addDoubleProperty("score");//添加Double的score    }}
4.運行java代碼,自動在Android project的java-gen目錄下產生bean類和DAO類

5.建立MyApplication繼承Application,並在Manifest檔案中配置
public class MyApplication extends Application{    public DaoSession daoSession;    public SQLiteDatabase db;    public DaoMaster.DevOpenHelper helper;    public DaoMaster daoMaster;    @Override    public void onCreate() {        super.onCreate();        setupDatabase();    }    private void setupDatabase() {        //建立資料庫        // 注意:預設的 DaoMaster.DevOpenHelper 會在資料庫升級時,刪除所有的表,意味著這將導致資料的丟失。        // 所以,在正式的項目中,你還應該做一層封裝,來實現資料庫的安全升級。        helper = new DaoMaster.DevOpenHelper(this, "test", null);        //得到資料庫連接對象        db = helper.getWritableDatabase();        //得到資料庫管理者        daoMaster =new DaoMaster(db);        //得到daoSession,可以執行增刪改查操作        daoSession = daoMaster.newSession();    }    public DaoSession getDaoSession() {        return daoSession;    }    public SQLiteDatabase getDb() {        return db;    }}
6.編寫MainActivity中的代碼,實現用greenDAO進行資料庫的操作

布局檔案

                                                    

初始化視圖

tv_id = (TextView)findViewById(R.id.tv_id);et_name = (EditText) findViewById(R.id.et_name);et_age = (EditText) findViewById(R.id.et_age);et_score = (EditText) findViewById(R.id.et_score);btn_add = (Button) findViewById(R.id.btn_add);btn_delete = (Button) findViewById(R.id.btn_delete);btn_update = (Button) findViewById(R.id.btn_update);btn_query = (Button) findViewById(R.id.btn_query);lv_list = (ListView) findViewById(R.id.lv_list);

得到cursor對象

String orderBy = EntityDao.Properties.Id.columnName + " DESC";//根據Id降序排序//查詢,得到cursorcursor = getDb().query(getEntityDao().getTablename(), getEntityDao().getAllColumns(), null, null, null, null, orderBy);

設定監聽

btn_add.setOnClickListener(this);btn_delete.setOnClickListener(this);btn_update.setOnClickListener(this);btn_query.setOnClickListener(this);adapter = new MyAdapter(this, cursor);lv_list.setAdapter(adapter);lv_list.setOnItemClickListener(new AdapterView.OnItemClickListener() {    @Override    public void onItemClick(AdapterView parent, View view, int position, long id_index) {        id = cursor.getLong(0);        tv_id.setText("id: "+id);        et_name.setText(cursor.getString(1));        et_age.setText(cursor.getInt(2) + "");        et_score.setText(cursor.getDouble(3) + "");    }});

自訂CursorAdapter

class MyAdapter extends CursorAdapter {    public MyAdapter(Context context, Cursor cursor) {        super(context, cursor);    }    @Override    public View newView(Context context, Cursor cursor, ViewGroup parent) {        ViewHolder holder = new ViewHolder();        LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);        View view = inflater.inflate(R.layout.item_db, parent, false);        holder.tv_id = (TextView) view.findViewById(R.id.tv_id);        holder.tv_name = (TextView) view.findViewById(R.id.tv_name);        holder.tv_age = (TextView) view.findViewById(R.id.tv_age);        holder.tv_score = (TextView) view.findViewById(R.id.tv_score);        view.setTag(holder);        return view;    }    @Override    public void bindView(View view, Context context, Cursor cursor) {        ViewHolder holder = (ViewHolder) view.getTag();        long id = cursor.getLong(0);        String name = cursor.getString(1);        int age = cursor.getInt(2);        double score = cursor.getDouble(3);        holder.tv_id.setText(id + "");        holder.tv_name.setText(name);        holder.tv_age.setText(age + "");        holder.tv_score.setText(score + "");    }}static class ViewHolder {    TextView tv_id;    TextView tv_name;    TextView tv_age;    TextView tv_score;}

資料庫操作:增刪改查的方法

/** * 添加 */private void addEntity() {    if (!TextUtils.isEmpty(name)) {        Entity entity = new Entity(null, name, age, score);        //物件導向添加表資料        getEntityDao().insert(entity);        cursor.requery();//重新整理    } else {        Toast.makeText(MainActivity.this, "name不可為空", Toast.LENGTH_SHORT).show();    }}/** * 根據id刪除 * * @param id */private void deleteEntity(long id) {    getEntityDao().deleteByKey(id);    cursor.requery();}/** * 更新 */private void updateList() {    Entity entity = new Entity(id, name, age, score);    getEntityDao().update(entity);    cursor.requery();}/** * 根據name查詢 * * @param name */private void query(String name) {    if (!TextUtils.isEmpty(this.name)) {        // Query 類代表了一個可以被重複執行的查詢        Query query = getEntityDao().queryBuilder()                .where(EntityDao.Properties.Name.eq(this.name))                .orderAsc(EntityDao.Properties.Id)                .build();        // 查詢結果以 List 返回        List count = query.list();        Toast.makeText(MainActivity.this, count.size() + "條資料被查到", Toast.LENGTH_SHORT).show();    } else {        Toast.makeText(MainActivity.this, "name不可為空", Toast.LENGTH_SHORT).show();    }}

demo示範:

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.