Grails,当一次插入出现异常时,批插入失败
我正在尝试使用从多个输入中检索的文件进行批插入。没有例外,一切都好。但是,当一个文件的内容不好导致一个异常时,其他所有异常都不会持久化。下面是我使用的代码:Grails,当一次插入出现异常时,批插入失败,grails,gorm,batch-processing,Grails,Gorm,Batch Processing,我正在尝试使用从多个输入中检索的文件进行批插入。没有例外,一切都好。但是,当一个文件的内容不好导致一个异常时,其他所有异常都不会持久化。下面是我使用的代码: def fileList = multiPartRequest.getFiles('files') def totalFile = fileList?.size(); fileList.eachWithIndex { file,int i -> try{ de
def fileList = multiPartRequest.getFiles('files')
def totalFile = fileList?.size();
fileList.eachWithIndex { file,int i ->
try{
def result=urlService.loadFile(file.getInputStream() as InputStream)
urlService.newUrlFromFile(params,result)
} catch (Exception e){
def errorFile = file.getOriginalFilename()
log.warn("Problem with file: $errorFile ",e)
errorsFiles.add(errorFile)
}
}
以及newUrlFromFile()
方法:
def newUrlFromFile(def params,Map result){
def datasetId = params?.dataset_id
def categories = result?.info as List
def catMap =[:]
Url url;
def dataset = DataSet.findById(datasetId)
if (datasetId){
if(categories){
catMap=[level1:categories[0],level2:categories[1],level3:categories[2]]
url=CSVLoaderService.saveUrlAndCategories(categories[3] as String,categories[0] as String,
categories[1] as String,categories[2] as String,dataset)
url.save(flush: true,failOnError: true)
dataset.save(flush: true, failOnError: true,deepValidate: false)
log.info("we have saved the categories")
}
Map doc =[dataset_id:datasetId,
url_id:url?.id as String,
meta_info:result?.meta,
title: result?.title,
categories:catMap,
dataset_lang:dataset.language]
}
}
谢谢最后,我可以使用以下方法解决问题:
try{
def result=urlService.loadFile(file.getInputStream() as InputStream)
DataSet.withNewTransaction {
urlService.newUrlFromFile(params,result)
}
} catch (Exception e){
def errorFile = file.getOriginalFilename()
log.warn("Problem with file: $errorFile ",e)
errorsFiles.add(errorFile)
flash.error="Problem encountered with file: ${file.getOriginalFilename()}";
}
这将在每次遇到新文件时打开一个新牵引 我只能假设这是因为您在一个事务中(可能有问题的类上存在
@transaction
),异常是回滚整个事务/休眠会话。是的,就是这样。你认为withTransaction
会奏效吗?