DBFlow源碼分析:model相關(guān)

類結(jié)構(gòu)

model相關(guān)

結(jié)構(gòu)說明

  1. Model提供表,字段等基本信息,
  2. ModelAdapter根據(jù)Model提供了一些功能職責(zé):增刪改查。dbflow根據(jù)你提供的信息生成具體的職責(zé)處理的代碼。
  3. ModeSaver是ModelAdapter的功能職責(zé)的維護者,它匯聚ModelAdapter的功能,再根據(jù)ModelAdapter提供的信息執(zhí)行具體的操作。

舉個例子

保存model信息到數(shù)據(jù)庫。

定義model信息:

@Table(name = "OtherModel", database = AppDatabase.class)
public class OtherModel extends BaseModel {

    @Column
    @PrimaryKey
    String name;
}

編譯后,生成的Adapter:OtherModel_Table

/**
 * This is generated code. Please do not modify */
public final class OtherModel_Table extends ModelAdapter<OtherModel> {

  //依據(jù)model信息,生成的字段信息:name
  /**
   * Primary Key */
  public static final Property<String> name = new Property<String>(OtherModel.class, "name");

  public static final IProperty[] ALL_COLUMN_PROPERTIES = new IProperty[]{name};

  public OtherModel_Table(DatabaseHolder holder, DatabaseDefinition databaseDefinition) {
    super(databaseDefinition);
  }

  @Override
  public final Class<OtherModel> getModelClass() {
    return OtherModel.class;
  }

  // 依據(jù)model信息,生成的表的名字:OtherModel
  public final String getTableName() {
    return "`OtherModel`";
  }

  @Override
  public final BaseProperty getProperty(String columnName) {
    columnName = QueryBuilder.quoteIfNeeded(columnName);
    switch (columnName)  {
      case "`name`":  {
        return name;
      }
      default:  {
        throw new IllegalArgumentException("Invalid column name passed. Ensure you are calling the correct table's column");
      }
    }
  }

  @Override
  public final IProperty[] getAllColumnProperties() {
    return ALL_COLUMN_PROPERTIES;
  }

  @Override
  public final void bindToInsertValues(ContentValues values, OtherModel model) {
    values.put("name", model.name != null ? model.name : null);
  }

  @Override
  public final void bindToContentValues(ContentValues values, OtherModel model) {
    bindToInsertValues(values, model);
  }

  @Override
  public final void bindToInsertStatement(DatabaseStatement statement, OtherModel model, int start) {
    if (model.name != null)  {
      statement.bindString(1 + start, model.name);
    } else {
      statement.bindNull(1 + start);
    }
  }

  @Override
  public final void bindToStatement(DatabaseStatement statement, OtherModel model) {
    bindToInsertStatement(statement, model, 0);
  }

  @Override
  public final String getInsertStatementQuery() {
    return "INSERT INTO `OtherModel`(`name`) VALUES (?)";
  }

  @Override
  public final String getCompiledStatementQuery() {
    return "INSERT INTO `OtherModel`(`name`) VALUES (?)";
  }

  @Override
  public final String getCreationQuery() {
    return "CREATE TABLE IF NOT EXISTS `OtherModel`(`name` TEXT, PRIMARY KEY(`name`)" + ");";
  }

  @Override
  public final void loadFromCursor(Cursor cursor, OtherModel model) {
    int index_name = cursor.getColumnIndex("name");
    if (index_name != -1 && !cursor.isNull(index_name)) {
      model.name = cursor.getString(index_name);
    } else {
      model.name = null;
    }
  }

  @Override
  public final boolean exists(OtherModel model, DatabaseWrapper wrapper) {
    return SQLite.selectCountOf()
    .from(OtherModel.class)
    .where(getPrimaryConditionClause(model))
    .hasData(wrapper);
  }

  @Override
  public final ConditionGroup getPrimaryConditionClause(OtherModel model) {
    ConditionGroup clause = ConditionGroup.clause();
    clause.and(name.eq(model.name));
    return clause;
  }

  @Override
  public final OtherModel newInstance() {
    return new OtherModel();
  }

保存這個model:

OtherModel otherModel= new OtherModel();
otherModel.name="wang";
otherModel.save();

交給adapter保存:

 public void save() {
        getModelAdapter().save(this);
 }

adapter交給modelSaver處理保存:

 public synchronized boolean save(@NonNull TModel model, DatabaseWrapper wrapper) {
        return save(model, wrapper, modelAdapter.getInsertStatement(wrapper), new ContentValues());
 }
save
  1. exist
    OtherModel_Table中生成的代碼:


  2. update
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,517評論 6 539
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,087評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,521評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,493評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,207評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,603評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,624評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,813評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,364評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 41,110評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,305評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,874評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,532評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,953評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,209評論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,033評論 3 396
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,268評論 2 375

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,692評論 25 708
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 31,729評論 18 399
  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 3,829評論 0 11
  • n有些人, 你見到第一眼,就感覺很舒服; 有的人, 即使認識了好幾年, 見面也是尷尬的幾句寒暄。 人和人之間, 一...
    芮倩閱讀 481評論 0 1
  • 不問值不值 只管愛不愛 一生如夢如幻的癡戀 是我若即若離的劫難 恰好你懦弱 恰巧我堅強 我要的只是你的陪伴 你守的...
    電影夫人閱讀 695評論 12 21