dbflow 批量 增删查改

Posted 晕菜一员

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了dbflow 批量 增删查改相关的知识,希望对你有一定的参考价值。

@ModelContainer
@Table(database = DemoDatabase.class)
class Person extends BaseModel implements Serializable {
    @PrimaryKey()
    int uid;
    @Column
    int age;
    @Column
    String name;

    ....
    ....  
}

下面例子主要用以上实体类。

1、可以通过增加外键来关联查询

// 比如增加infoId作为外键

// 1 查询
// 使用Table类进行字段查询
List<Person> persons = new Select().from(Person.class)
                .where(Person_Table.infoId.eq(infoId))
                .queryList();

// 2 删除
// 可通过写Condition条件进行删除。
SQLCondition condition = Condition.column(Person_Table.infoId.getNameAlias()).eq(infoId);

Delete.table(Person.class).where(condition);

2、通过in进行操作。

List<Integer> uidList = new ArrayList<>();
SQLCondition condition = Condition.column(Person_Table.uid.getNameAlias()).in(uidList);

// 1 查询
List<Person> persons = new Select().from(Person.class)
                .where(condition)
                .queryList();

// 2 删除
Delete.table(Person.class, condition);

dbflow保存操作:

在github 的 issue上有一个bug,上面说,db.reset();后,保存会出现主键是唯一的异常。我更新了beta6后,发现不能使用一个批量保存list的方法了。

即是使用:

new SaveModelTransaction<>(ProcessModelInfo.withModels(peoples)).onExecute();

在save方法上出现如下异常:

android.database.sqlite.SQLiteConstraintException: PRIMARY KEY must be unique
....
....
....

这个相关联的类以及方法,全部在beta6版本中去除。然后只提供了事务管理。

让我们自己去实现事务批量保存,结果可以了。完美兼容。

DatabaseDefinition database = FlowManager.getDatabase(DemoDatabase.class);
        Transaction transaction = database.beginTransactionAsync(new ITransaction() {
            @Override
            public void execute(DatabaseWrapper databaseWrapper) {
          // todo 处理list保存
          ...
          ...
       }
        }).build();
transaction.execute();

 

以上是关于dbflow 批量 增删查改的主要内容,如果未能解决你的问题,请参考以下文章

EF基本操作增删查改分页,join……等

2016/3/13 MySQL 增删查改 CRUD 用代码实现

php mysql增删查改

基于MVC实现增删查改

基于MVC实现增删查改

php怎么对文件内容进行增删查改?