gpt4 book ai didi

android - OrmLite 执行sql语句

转载 作者:行者123 更新时间:2023-11-29 20:24:31 25 4
gpt4 key购买 nike

我在 OrmLite 中有一个数据库。这是其中一个表 — Field:

@DatabaseTable
public class Field {

@DatabaseField(generatedId = true)
private long id;

@DatabaseField
private String type;

@ForeignCollectionField(eager = true)
private Collection<FieldListValue> listValue;
...
}

我想像这样从表中删除一些值:

List<Field> fields = fieldDao.queryForAll();
for (Field field : fields) {
if (field.getType().equals("list") && field.getListValue().size() == 0) {
fieldDao.delete(field);
}
}

但是如何使用 DeleteBuilder 执行此查询?

这段代码的问题 ...(SELECT COUNT(listValue) FROM Field) = 0

最佳答案

But how can I execute this query with DeleteBuilder ?

没有直接的方法可以使用 DeleteBuilder 来执行此操作,因为外部对象实际上在 Field 类中没有任何信息。

但是,这里有一种方法可以使用原始查询然后使用 DeleteBuilder 来完成此操作。

近似代码:

qb = fieldListValueDao.queryBuilder();
// raw query for the field_ids in the fieldListValue table
rawResults = qb.queryRaw("SELECT field_id FROM fieldListValue GROUP BY field_id",
new RawRowMapper<Integer>() {
// each result row is a single integer in the 0th column
public Integer mapRow(String[] columnNames, String[] resultColumns) {
return Integer.parseInt(resultColumns[0]);
}
});

有关原始查询的帮助,请参阅:http://ormlite.com/docs/raw-queries

一旦您获得了 field_id 值的原始结果,您就可以:

deleteBuilder = fieldDao.deleteBuilder();
// delete any rows that are not in the raw-results -- who have no fieldListValue entries
deleteBuilder.where().notIn("id", rawResults);
deleteBuilder.delete();

您也可以使用 notIn("id", queryBuilder) 方法来完成此操作:

qb = fieldListValueDao.queryBuilder();
qb.selectColumns("field_id");
qb.groupBy("field_id");
...
deleteBuilder = fieldDao.deleteBuilder();
deleteBuilder.where().notIn("id", qb);
deleteBuilder.delete();

不过,我需要检查一下以确保。

希望这对您有所帮助。

关于android - OrmLite 执行sql语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32736275/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com