2016-07-04 269 views

回答

0

它会抛出此异常是方法的流程:

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 转换。因此,任何不会抛出任何异常的插入都会成功。

+0

但文档不会说它会抛出异常或类似的东西。 – andyPaul

+0

这里是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 –

+0

有些情况下会让mongo不写数据的是 1.磁盘空间已满,2.切断3.访问权限 我们可以很容易地重现1和3.在插入前运行代码把调试器发生。代码执行停止。关闭monogo服务器或撤销用户的写权限,然后恢复。它应该抛出异常。 –