Я гоняюсь за серьезной ошибкой в нашем приложении, и после некоторого копания я разбил ее до этого примера.Используя коллекцию Джексона, я не могу удалить документы.Обычно это работает для одного документа, который я только что вставил.В следующем примере я просто пытаюсь очистить коллекцию unittest.
import java.net.UnknownHostException;
import net.vz.mongodb.jackson.DBCursor;
import net.vz.mongodb.jackson.JacksonDBCollection;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.Mongo;
import com.mongodb.MongoException;
import com.test.model.Account;
public class MongoTest {
public static void main(String[] args) {
try {
Mongo mongo = new Mongo("localhost", 27017);
DB db = mongo.getDB("orion-unittest");
// get a single collection
DBCollection collection = db.getCollection("account");
JacksonDBCollection<Account, String> jacksonCollection = JacksonDBCollection.wrap(collection, Account.class, String.class);
// doesn't work
DBCursor<Account> jacksonCursor = jacksonCollection.find();
while (jacksonCursor.hasNext()) {
jacksonCollection.remove(jacksonCursor.next());
}
System.out.println(jacksonCollection.getCount());
// works!
com.mongodb.DBCursor cursor = collection.find();
while (cursor.hasNext()) {
collection.remove(cursor.next());
}
System.out.println(collection.getCount());
} catch (UnknownHostException e) {
e.printStackTrace();
} catch (MongoException e) {
e.printStackTrace();
}
}
}
Консольный вывод:60
Странно то, что когда я наблюдаю за действиями сервера Монго, я вижу, что передаются команды удаления.я что-то пропустил, или это ошибка Джексона Маппера?
здесь класс Account - ничего особенного нет.идентификатор заполнен ключом _id:
import net.vz.mongodb.jackson.Id;
public class Account {
@Id
String id;
String nickname = null;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getNickname() {
return nickname;
}
public void setNickname(String nickname) {
this.nickname = nickname;
}
}