Spring Jdbc выполнение запроса - PullRequest
1 голос
/ 20 января 2010

Кто-нибудь знает, как какой шаблонный метод Spring Jdbc я мог бы использовать для выполнения этого 'upsert' или альтернативного подхода, который также выполнял бы операции в одном вызове базы данных?

UPDATE jasper_report SET Uri = 'update' WHERE ReportId = 99;
IF @@ROWCOUNT = 0 AND Exists(Select 1 FROM report Where Id = 99)
BEGIN   
    INSERT INTO jasper_report  (ReportId, Uri) VALUES (99, 'insert') 
END;

Ответы [ 2 ]

3 голосов
/ 21 января 2010

Оказывается, я был близко, но забыл шаг.

Мне пришлось изменить сам запрос на:

BEGIN 
  UPDATE jasper_report SET Uri = ? WHERE ReportId = ? 
  IF @@ROWCOUNT = 0 AND EXISTS(SELECT 1 FROM report WHERE Id = ?) 
  BEGIN 
       INSERT INTO jasper_report  (ReportId, Uri) VALUES (?, ?) 
  END 
END

Тогда в моем Dao нужно было только использовать Метод обновления JdbcTemplate Spring . Это выглядит примерно так:

@Repository("jasperReportsDao")
public class JasperReportsDaoImpl extends JdbcTemplate implements JasperReportsDao {

    @Override
    public void saveJasperReport(JasperReport report) {
        // If a record already exists, do an update, otherwise, do an insert
        int rowsAffected = this.update(UPSERT_JASPER_REPORT, new Object[] { report.getUri(), report.getId(),
                               report.getId(), report.getId(), report.getUri()} );

        if(log.isDebugEnabled()) { log.debug("Rows affected: " + rowsAffected); }
    }
}
1 голос
/ 21 января 2010

Разве это не должно быть Not Exists?

В любом случае, я думаю, что без Not Exists все будет работать нормально, поскольку @@ROWCOUNT уже дает вам эту информацию:

UPDATE jasper_report SET Uri = 'update' WHERE ReportId = 99;
IF @@ROWCOUNT = 0 
BEGIN   
    INSERT INTO jasper_report (ReportId, Uri) VALUES (99, 'insert') 
END;
...