summaryrefslogtreecommitdiff
path: root/spring-jdbc/src/main/java/org/springframework/jdbc/core/BatchUpdateUtils.java
diff options
context:
space:
mode:
authorEmmanuel Bourg <ebourg@apache.org>2014-12-03 14:31:16 +0100
committerEmmanuel Bourg <ebourg@apache.org>2014-12-03 14:31:16 +0100
commitc56370beb0a2bfa263e125fce107dceccee89fd3 (patch)
tree7ee611ceb0acbbdf7f83abcd72adb854b7d77225 /spring-jdbc/src/main/java/org/springframework/jdbc/core/BatchUpdateUtils.java
parentaa5221b73661fa728dc4e62e1230e9104528c4eb (diff)
Imported Upstream version 3.2.12
Diffstat (limited to 'spring-jdbc/src/main/java/org/springframework/jdbc/core/BatchUpdateUtils.java')
-rw-r--r--spring-jdbc/src/main/java/org/springframework/jdbc/core/BatchUpdateUtils.java68
1 files changed, 68 insertions, 0 deletions
diff --git a/spring-jdbc/src/main/java/org/springframework/jdbc/core/BatchUpdateUtils.java b/spring-jdbc/src/main/java/org/springframework/jdbc/core/BatchUpdateUtils.java
new file mode 100644
index 00000000..2785e6a1
--- /dev/null
+++ b/spring-jdbc/src/main/java/org/springframework/jdbc/core/BatchUpdateUtils.java
@@ -0,0 +1,68 @@
+/*
+ * Copyright 2002-2008 the original author or authors.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.springframework.jdbc.core;
+
+import java.util.List;
+import java.sql.PreparedStatement;
+import java.sql.SQLException;
+
+/**
+ * Generic utility methods for working with JDBC batch statements. Mainly for internal use
+ * within the framework.
+ *
+ * @author Thomas Risberg
+ */
+public abstract class BatchUpdateUtils {
+
+ public static int[] executeBatchUpdate(String sql, final List<Object[]> batchValues, final int[] columnTypes, JdbcOperations jdbcOperations) {
+ return jdbcOperations.batchUpdate(
+ sql,
+ new BatchPreparedStatementSetter() {
+
+ public void setValues(PreparedStatement ps, int i) throws SQLException {
+ Object[] values = batchValues.get(i);
+ setStatementParameters(values, ps, columnTypes);
+ }
+
+ public int getBatchSize() {
+ return batchValues.size();
+ }
+ });
+ }
+
+ protected static void setStatementParameters(Object[] values, PreparedStatement ps, int[] columnTypes) throws SQLException {
+ int colIndex = 0;
+ for (Object value : values) {
+ colIndex++;
+ if (value instanceof SqlParameterValue) {
+ SqlParameterValue paramValue = (SqlParameterValue) value;
+ StatementCreatorUtils.setParameterValue(ps, colIndex, paramValue, paramValue.getValue());
+ }
+ else {
+ int colType;
+ if (columnTypes == null || columnTypes.length < colIndex) {
+ colType = SqlTypeValue.TYPE_UNKNOWN;
+ }
+ else {
+ colType = columnTypes[colIndex - 1];
+ }
+ StatementCreatorUtils.setParameterValue(ps, colIndex, colType, value);
+ }
+ }
+ }
+
+}