當前位置: 首頁>>代碼示例>>Java>>正文


Java InvalidDataAccessApiUsageException類代碼示例

本文整理匯總了Java中org.springframework.dao.InvalidDataAccessApiUsageException的典型用法代碼示例。如果您正苦於以下問題:Java InvalidDataAccessApiUsageException類的具體用法?Java InvalidDataAccessApiUsageException怎麽用?Java InvalidDataAccessApiUsageException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


InvalidDataAccessApiUsageException類屬於org.springframework.dao包,在下文中一共展示了InvalidDataAccessApiUsageException類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: validateNamedParameters

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
/**
 * Validate the named parameters passed to an execute method based on declared parameters.
 * Subclasses should invoke this method before every {@code executeQuery()} or
 * {@code update()} method.
 * @param parameters parameter Map supplied. May be {@code null}.
 * @throws InvalidDataAccessApiUsageException if the parameters are invalid
 */
protected void validateNamedParameters(Map<String, ?> parameters) throws InvalidDataAccessApiUsageException {
	checkCompiled();
	Map<String, ?> paramsToUse = (parameters != null ? parameters : Collections.<String, Object> emptyMap());
	int declaredInParameters = 0;
	for (SqlParameter param : this.declaredParameters) {
		if (param.isInputValueProvided()) {
			if (!supportsLobParameters() &&
					(param.getSqlType() == Types.BLOB || param.getSqlType() == Types.CLOB)) {
				throw new InvalidDataAccessApiUsageException(
						"BLOB or CLOB parameters are not allowed for this kind of operation");
			}
			if (param.getName() != null && !paramsToUse.containsKey(param.getName())) {
				throw new InvalidDataAccessApiUsageException("The parameter named '" + param.getName() +
						"' was not among the parameters supplied: " + paramsToUse.keySet());
			}
			declaredInParameters++;
		}
	}
	validateParameterCount(paramsToUse.size(), declaredInParameters);
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:28,代碼來源:RdbmsOperation.java

示例2: testParametersSetWithList

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
public void testParametersSetWithList() {
	TestRdbmsOperation operation = new TestRdbmsOperation();
	DataSource ds = new DriverManagerDataSource();
	operation.setDataSource(ds);
	operation.setSql("select * from mytable where one = ? and two = ?");
	List l = new ArrayList();
	l.add(new SqlParameter("one", Types.NUMERIC));
	l.add(new SqlParameter("two", Types.VARCHAR));
	operation.setParameters(new SqlParameter[] {
			new SqlParameter("one", Types.NUMERIC),
			new SqlParameter("two", Types.NUMERIC)});
	operation.afterPropertiesSet();
	try {
		operation.validateParameters(new Object[] {new Integer(1), new String("2")});
		assertEquals(2, operation.getDeclaredParameters().size());
		// OK
	}
	catch (InvalidDataAccessApiUsageException idaauex) {
		fail("Should have validated with parameters set using List: " + idaauex.getMessage());
	}
}
 
開發者ID:deathspeeder,項目名稱:class-guard,代碼行數:22,代碼來源:RdbmsOperationTests.java

示例3: getKey

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
@Override
public Number getKey() throws InvalidDataAccessApiUsageException, DataRetrievalFailureException {
	if (this.keyList.size() == 0) {
		return null;
	}
	if (this.keyList.size() > 1 || this.keyList.get(0).size() > 1) {
		throw new InvalidDataAccessApiUsageException(
				"The getKey method should only be used when a single key is returned.  " +
				"The current key entry contains multiple keys: " + this.keyList);
	}
	Iterator<Object> keyIter = this.keyList.get(0).values().iterator();
	if (keyIter.hasNext()) {
		Object key = keyIter.next();
		if (!(key instanceof Number)) {
			throw new DataRetrievalFailureException(
					"The generated key is not of a supported numeric type. " +
					"Unable to cast [" + (key != null ? key.getClass().getName() : null) +
					"] to [" + Number.class.getName() + "]");
		}
		return (Number) key;
	}
	else {
		throw new DataRetrievalFailureException("Unable to retrieve the generated key. " +
				"Check that the table has an identity column enabled.");
	}
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:27,代碼來源:GeneratedKeyHolder.java

示例4: compile

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
/**
 * Compile this query.
 * Ignores subsequent attempts to compile.
 * @throws InvalidDataAccessApiUsageException if the object hasn't
 * been correctly initialized, for example if no DataSource has been provided
 */
public final void compile() throws InvalidDataAccessApiUsageException {
	if (!isCompiled()) {
		if (getSql() == null) {
			throw new InvalidDataAccessApiUsageException("Property 'sql' is required");
		}

		try {
			this.jdbcTemplate.afterPropertiesSet();
		}
		catch (IllegalArgumentException ex) {
			throw new InvalidDataAccessApiUsageException(ex.getMessage());
		}

		compileInternal();
		this.compiled = true;

		if (logger.isDebugEnabled()) {
			logger.debug("RdbmsOperation with SQL [" + getSql() + "] compiled");
		}
	}
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:28,代碼來源:RdbmsOperation.java

示例5: validateParameters

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
/**
 * Validate the parameters passed to an execute method based on declared parameters.
 * Subclasses should invoke this method before every {@code executeQuery()}
 * or {@code update()} method.
 * @param parameters parameters supplied (may be {@code null})
 * @throws InvalidDataAccessApiUsageException if the parameters are invalid
 */
protected void validateParameters(Object[] parameters) throws InvalidDataAccessApiUsageException {
	checkCompiled();
	int declaredInParameters = 0;
	for (SqlParameter param : this.declaredParameters) {
		if (param.isInputValueProvided()) {
			if (!supportsLobParameters() &&
					(param.getSqlType() == Types.BLOB || param.getSqlType() == Types.CLOB)) {
				throw new InvalidDataAccessApiUsageException(
						"BLOB or CLOB parameters are not allowed for this kind of operation");
			}
			declaredInParameters++;
		}
	}
	validateParameterCount((parameters != null ? parameters.length : 0), declaredInParameters);
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:23,代碼來源:RdbmsOperation.java

示例6: PreparedStatementCreatorImpl

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
public PreparedStatementCreatorImpl(String actualSql, List<?> parameters) {
	this.actualSql = actualSql;
	Assert.notNull(parameters, "Parameters List must not be null");
	this.parameters = parameters;
	if (this.parameters.size() != declaredParameters.size()) {
		// account for named parameters being used multiple times
		Set<String> names = new HashSet<String>();
		for (int i = 0; i < parameters.size(); i++) {
			Object param = parameters.get(i);
			if (param instanceof SqlParameterValue) {
				names.add(((SqlParameterValue) param).getName());
			}
			else {
				names.add("Parameter #" + i);
			}
		}
		if (names.size() != declaredParameters.size()) {
			throw new InvalidDataAccessApiUsageException(
					"SQL [" + sql + "]: given " + names.size() +
					" parameters but expected " + declaredParameters.size());
		}
	}
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:24,代碼來源:PreparedStatementCreatorFactory.java

示例7: compile

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
/**
 * Compile this JdbcInsert using provided parameters and meta data plus other settings.
 * This finalizes the configuration for this object and subsequent attempts to compile are
 * ignored. This will be implicitly called the first time an un-compiled insert is executed.
 * @throws InvalidDataAccessApiUsageException if the object hasn't been correctly initialized,
 * for example if no DataSource has been provided
 */
public synchronized final void compile() throws InvalidDataAccessApiUsageException {
	if (!isCompiled()) {
		if (getTableName() == null) {
			throw new InvalidDataAccessApiUsageException("Table name is required");
		}
		try {
			this.jdbcTemplate.afterPropertiesSet();
		}
		catch (IllegalArgumentException ex) {
			throw new InvalidDataAccessApiUsageException(ex.getMessage());
		}
		compileInternal();
		this.compiled = true;
		if (logger.isDebugEnabled()) {
			logger.debug("JdbcInsert for table [" + getTableName() + "] compiled");
		}
	}
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:26,代碼來源:AbstractJdbcInsert.java

示例8: prepareStatementForGeneratedKeys

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
/**
 * Create the PreparedStatement to be used for insert that have generated keys
 *
 * @param con the connection used
 * @return PreparedStatement to use
 * @throws SQLException
 */
private PreparedStatement prepareStatementForGeneratedKeys(Connection con) throws SQLException {
	if (getGeneratedKeyNames().length < 1) {
		throw new InvalidDataAccessApiUsageException("Generated Key Name(s) not specificed. " +
				"Using the generated keys features requires specifying the name(s) of the generated column(s)");
	}
	PreparedStatement ps;
	if (this.tableMetaDataContext.isGeneratedKeysColumnNameArraySupported()) {
		if (logger.isDebugEnabled()) {
			logger.debug("Using generated keys support with array of column names.");
		}
		ps = con.prepareStatement(getInsertString(), getGeneratedKeyNames());
	}
	else {
		if (logger.isDebugEnabled()) {
			logger.debug("Using generated keys support with Statement.RETURN_GENERATED_KEYS.");
		}
		ps = con.prepareStatement(getInsertString(), Statement.RETURN_GENERATED_KEYS);
	}
	return ps;
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:28,代碼來源:AbstractJdbcInsert.java

示例9: addDeclaredParameter

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
/**
 * Add a declared parameter to the list of parameters for the call.
 * Only parameters declared as {@code SqlParameter} and {@code SqlInOutParameter}
 * will be used to provide input values. This is different from the {@code StoredProcedure} class
 * which for backwards compatibility reasons allows input values to be provided for parameters declared
 * as {@code SqlOutParameter}.
 * @param parameter the {@link SqlParameter} to add
 */
public void addDeclaredParameter(SqlParameter parameter) {
	Assert.notNull(parameter, "The supplied parameter must not be null");
	if (!StringUtils.hasText(parameter.getName())) {
		throw new InvalidDataAccessApiUsageException(
				"You must specify a parameter name when declaring parameters for \"" + getProcedureName() + "\"");
	}
	this.declaredParameters.add(parameter);
	if (logger.isDebugEnabled()) {
		logger.debug("Added declared parameter for [" + getProcedureName() + "]: " + parameter.getName());
	}
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:20,代碼來源:AbstractJdbcCall.java

示例10: compile

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
/**
 * Compile this JdbcCall using provided parameters and meta data plus other settings.  This
 * finalizes the configuration for this object and subsequent attempts to compile are ignored.
 * This will be implicitly called the first time an un-compiled call is executed.
 * @throws org.springframework.dao.InvalidDataAccessApiUsageException if the object hasn't
 * been correctly initialized, for example if no DataSource has been provided
 */
public synchronized final void compile() throws InvalidDataAccessApiUsageException {
	if (!isCompiled()) {
		if (getProcedureName() == null) {
			throw new InvalidDataAccessApiUsageException("Procedure or Function name is required");
		}
		try {
			this.jdbcTemplate.afterPropertiesSet();
		}
		catch (IllegalArgumentException ex) {
			throw new InvalidDataAccessApiUsageException(ex.getMessage());
		}
		compileInternal();
		this.compiled = true;
		if (logger.isDebugEnabled()) {
			logger.debug("SqlCall for " + (isFunction() ? "function" : "procedure") + " [" + getProcedureName() + "] compiled");
		}
	}
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:26,代碼來源:AbstractJdbcCall.java

示例11: init

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
@Override
public void init(DataSource dataSource) throws Exception {
	Assert.notNull(dataSource);
	Assert.hasLength(selectClause, "selectClause must be specified");
	Assert.hasLength(fromClause, "fromClause must be specified");
	Assert.notEmpty(sortKeys, "sortKey must be specified");
	StringBuilder sql = new StringBuilder();
	sql.append("SELECT ").append(selectClause);
	sql.append(" FROM ").append(fromClause);
	if (whereClause != null) {
		sql.append(" WHERE ").append(whereClause);
	}
	List<String> namedParameters = new ArrayList<String>();
	parameterCount = JdbcParameterUtils.countParameterPlaceholders(sql.toString(), namedParameters);
	if (namedParameters.size() > 0) {
		if (parameterCount != namedParameters.size()) {
			throw new InvalidDataAccessApiUsageException(
					"You can't use both named parameters and classic \"?\" placeholders: " + sql);
		}
		usingNamedParameters = true;
	}
}
 
開發者ID:spring-cloud,項目名稱:spring-cloud-dashboard,代碼行數:23,代碼來源:AbstractSqlPagingQueryProvider.java

示例12: fromInequalityVariant

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
private Predicate<?> fromInequalityVariant(Type type, boolean ignoreCase, Iterator<Comparable<?>> iterator) {

		if (ignoreCase && type != Type.SIMPLE_PROPERTY) {
			throw new InvalidDataAccessApiUsageException(String.format("Ignore case not supported for '%s'", type));
		}

		switch (type) {

		case GREATER_THAN:
			return GreaterLessPredicate.gr(iterator.next());
		case GREATER_THAN_EQUAL:
			return GreaterLessPredicate.ge(iterator.next());
		case LESS_THAN:
			return GreaterLessPredicate.ls(iterator.next());
		case LESS_THAN_EQUAL:
			return GreaterLessPredicate.le(iterator.next());

		default:
			throw new InvalidDataAccessApiUsageException(String.format("Logic error for '%s' in query", type));
		}
	}
 
開發者ID:mrfrag,項目名稱:spring-data-mapdb,代碼行數:22,代碼來源:QueryCreator.java

示例13: doExecute

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
@Override
protected Object doExecute(final AbstractEbeanQuery ebeanQuery, Object[] values) {
  if (!SurroundingTransactionDetectorMethodInterceptor.INSTANCE.isSurroundingTransactionActive()) {
    throw new InvalidDataAccessApiUsageException(NO_SURROUNDING_TRANSACTION);
  }

  Object createQuery = ebeanQuery.createQuery(values);
  if (createQuery instanceof Query) {
    Query ormQuery = (Query) createQuery;
    QueryIterator<Object> iter = ormQuery.findIterate();

    return StreamUtils.createStreamFromIterator(iter);
  } else if (createQuery instanceof SqlQuery) {
    throw new InvalidEbeanQueryMethodException("query must be Query");
  } else {
    throw new InvalidEbeanQueryMethodException("query must be Query or SqlQuery");
  }
}
 
開發者ID:hexagonframework,項目名稱:spring-data-ebean,代碼行數:19,代碼來源:AbstractEbeanQueryExecution.java

示例14: prepareStatementForGeneratedKeys

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
/**
 * Create a PreparedStatement to be used for an insert operation with generated keys.
 * @param con the Connection to use
 * @return the PreparedStatement
 */
private PreparedStatement prepareStatementForGeneratedKeys(Connection con) throws SQLException {
	if (getGeneratedKeyNames().length < 1) {
		throw new InvalidDataAccessApiUsageException("Generated Key Name(s) not specified. " +
				"Using the generated keys features requires specifying the name(s) of the generated column(s).");
	}
	PreparedStatement ps;
	if (this.tableMetaDataContext.isGeneratedKeysColumnNameArraySupported()) {
		if (logger.isDebugEnabled()) {
			logger.debug("Using generated keys support with array of column names.");
		}
		ps = con.prepareStatement(getInsertString(), getGeneratedKeyNames());
	}
	else {
		if (logger.isDebugEnabled()) {
			logger.debug("Using generated keys support with Statement.RETURN_GENERATED_KEYS.");
		}
		ps = con.prepareStatement(getInsertString(), Statement.RETURN_GENERATED_KEYS);
	}
	return ps;
}
 
開發者ID:langtianya,項目名稱:spring4-understanding,代碼行數:26,代碼來源:AbstractJdbcInsert.java

示例15: compile

import org.springframework.dao.InvalidDataAccessApiUsageException; //導入依賴的package包/類
/**
 * Compile this JdbcCall using provided parameters and meta data plus other settings.
 * <p>This finalizes the configuration for this object and subsequent attempts to compile are
 * ignored. This will be implicitly called the first time an un-compiled call is executed.
 * @throws org.springframework.dao.InvalidDataAccessApiUsageException if the object hasn't
 * been correctly initialized, for example if no DataSource has been provided
 */
public synchronized final void compile() throws InvalidDataAccessApiUsageException {
	if (!isCompiled()) {
		if (getProcedureName() == null) {
			throw new InvalidDataAccessApiUsageException("Procedure or Function name is required");
		}
		try {
			this.jdbcTemplate.afterPropertiesSet();
		}
		catch (IllegalArgumentException ex) {
			throw new InvalidDataAccessApiUsageException(ex.getMessage());
		}
		compileInternal();
		this.compiled = true;
		if (logger.isDebugEnabled()) {
			logger.debug("SqlCall for " + (isFunction() ? "function" : "procedure") +
					" [" + getProcedureName() + "] compiled");
		}
	}
}
 
開發者ID:langtianya,項目名稱:spring4-understanding,代碼行數:27,代碼來源:AbstractJdbcCall.java


注:本文中的org.springframework.dao.InvalidDataAccessApiUsageException類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。