/*
 * Copyright 2002-2018 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.support.incrementer;

import javax.sql.DataSource;

import org.springframework.beans.factory.InitializingBean;
import org.springframework.dao.DataAccessException;
import org.springframework.util.Assert;

Base implementation of DataFieldMaxValueIncrementer that delegates to a single getNextKey template method that returns a long. Uses longs for String values, padding with zeroes if required.
Author:Dmitriy Kopylenko, Juergen Hoeller, Jean-Pierre Pawlak, Juergen Hoeller
/** * Base implementation of {@link DataFieldMaxValueIncrementer} that delegates * to a single {@link #getNextKey} template method that returns a {@code long}. * Uses longs for String values, padding with zeroes if required. * * @author Dmitriy Kopylenko * @author Juergen Hoeller * @author Jean-Pierre Pawlak * @author Juergen Hoeller */
public abstract class AbstractDataFieldMaxValueIncrementer implements DataFieldMaxValueIncrementer, InitializingBean { private DataSource dataSource;
The name of the sequence/table containing the sequence.
/** The name of the sequence/table containing the sequence. */
private String incrementerName;
The length to which a string result should be pre-pended with zeroes.
/** The length to which a string result should be pre-pended with zeroes. */
protected int paddingLength = 0;
Default constructor for bean property style usage.
See Also:
/** * Default constructor for bean property style usage. * @see #setDataSource * @see #setIncrementerName */
public AbstractDataFieldMaxValueIncrementer() { }
Convenience constructor.
Params:
  • dataSource – the DataSource to use
  • incrementerName – the name of the sequence/table to use
/** * Convenience constructor. * @param dataSource the DataSource to use * @param incrementerName the name of the sequence/table to use */
public AbstractDataFieldMaxValueIncrementer(DataSource dataSource, String incrementerName) { Assert.notNull(dataSource, "DataSource must not be null"); Assert.notNull(incrementerName, "Incrementer name must not be null"); this.dataSource = dataSource; this.incrementerName = incrementerName; }
Set the data source to retrieve the value from.
/** * Set the data source to retrieve the value from. */
public void setDataSource(DataSource dataSource) { this.dataSource = dataSource; }
Return the data source to retrieve the value from.
/** * Return the data source to retrieve the value from. */
public DataSource getDataSource() { return this.dataSource; }
Set the name of the sequence/table.
/** * Set the name of the sequence/table. */
public void setIncrementerName(String incrementerName) { this.incrementerName = incrementerName; }
Return the name of the sequence/table.
/** * Return the name of the sequence/table. */
public String getIncrementerName() { return this.incrementerName; }
Set the padding length, i.e. the length to which a string result should be pre-pended with zeroes.
/** * Set the padding length, i.e. the length to which a string result * should be pre-pended with zeroes. */
public void setPaddingLength(int paddingLength) { this.paddingLength = paddingLength; }
Return the padding length for String values.
/** * Return the padding length for String values. */
public int getPaddingLength() { return this.paddingLength; } @Override public void afterPropertiesSet() { if (this.dataSource == null) { throw new IllegalArgumentException("Property 'dataSource' is required"); } if (this.incrementerName == null) { throw new IllegalArgumentException("Property 'incrementerName' is required"); } } @Override public int nextIntValue() throws DataAccessException { return (int) getNextKey(); } @Override public long nextLongValue() throws DataAccessException { return getNextKey(); } @Override public String nextStringValue() throws DataAccessException { String s = Long.toString(getNextKey()); int len = s.length(); if (len < this.paddingLength) { StringBuilder sb = new StringBuilder(this.paddingLength); for (int i = 0; i < this.paddingLength - len; i++) { sb.append('0'); } sb.append(s); s = sb.toString(); } return s; }
Determine the next key to use, as a long.
Returns:the key to use as a long. It will eventually be converted later in another format by the public concrete methods of this class.
/** * Determine the next key to use, as a long. * @return the key to use as a long. It will eventually be converted later * in another format by the public concrete methods of this class. */
protected abstract long getNextKey(); }