它会抛出此异常是方法的流程:
template.insert(object)
|
|
templateinsert(Object objectToSave, String collectionName)
|
|
protected <T> void doInsert(String collectionName, T objectToSave, MongoWriter<T> writer)
|
|
protected Object insertDBObject(final String collectionName, final DBObject dbDoc, final Class<?> entityClass)
|
|
这里是insertDBObject
protected Object insertDBObject(final String collectionName, final DBObject dbDoc, final Class<?> entityClass) {
if(LOGGER.isDebugEnabled()) {
LOGGER.debug("Inserting DBObject containing fields: {} in collection: {}", dbDoc.keySet(), collectionName);
}
return this.execute(collectionName, new CollectionCallback() {
public Object doInCollection(DBCollection collection) throws MongoException, DataAccessException {
MongoAction mongoAction = new MongoAction(MongoTemplate.this.writeConcern, MongoActionOperation.INSERT, collectionName, entityClass, dbDoc, (DBObject)null);
WriteConcern writeConcernToUse = MongoTemplate.this.prepareWriteConcern(mongoAction);
WriteResult writeResult = writeConcernToUse == null?collection.insert(new DBObject[]{dbDoc}):collection.insert(dbDoc, writeConcernToUse);
MongoTemplate.this.handleAnyWriteResultErrors(writeResult, dbDoc, MongoActionOperation.INSERT);
return dbDoc.get("_id");
}
});
}
的源代码,这将抛出当你写失败例外,他们是运行时异常。运行时问题由MongoExceptionTranslator 转换。因此,任何不会抛出任何异常的插入都会成功。
但文档不会说它会抛出异常或类似的东西。 – andyPaul
这里是grepcode的墨水http://grepcode.com/file/repo1.maven.org/maven2/org.springframework.data/spring-data-mongodb/1.7.2.RELEASE/org/springframework/data/mongodb /core/MongoTemplate.java –
有些情况下会让mongo不写数据的是 1.磁盘空间已满,2.切断3.访问权限 我们可以很容易地重现1和3.在插入前运行代码把调试器发生。代码执行停止。关闭monogo服务器或撤销用户的写权限,然后恢复。它应该抛出异常。 –