All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.j256.ormlite.stmt.ArgumentHolder Maven / Gradle / Ivy

Go to download

Lightweight Object Relational Model (ORM) for persisting objects to SQL databases.

There is a newer version: 6.1
Show newest version
package com.j256.ormlite.stmt;

import java.sql.SQLException;

import com.j256.ormlite.field.FieldType;
import com.j256.ormlite.field.SqlType;

/**
 * An argument to a select SQL statement. After the query is constructed, the caller can set the value on this argument
 * and run the query. Then the argument can be set again and the query re-executed. This is equivalent in SQL to a ?
 * argument.
 * 
 * @author graywatson
 */
public interface ArgumentHolder {

	/**
	 * Return the column-name associated with this argument. The name is set by the package internally.
	 */
	public String getColumnName();

	/**
	 * Used internally by the package to set the column-name associated with this argument.
	 */
	public void setMetaInfo(String columnName);

	/**
	 * Used internally by the package to set the fieldType associated with this argument.
	 */
	public void setMetaInfo(FieldType fieldType);

	/**
	 * Used internally by the package to set the column-name and fieldType associated with this argument.
	 */
	public void setMetaInfo(String columnName, FieldType fieldType);

	/**
	 * Set the value associated with this argument. The value should be set by the user after the query has been built
	 * but before it has been executed.
	 */
	public void setValue(Object value);

	/**
	 * Return the value associated with this argument suitable for passing to SQL. The value should be set by the user
	 * before it is consumed.
	 */
	public Object getSqlArgValue() throws SQLException;

	/**
	 * Return the SQL type associated with this class. Either this or the field-type must be available.
	 */
	public SqlType getSqlType();

	/**
	 * Return the field type associated with this class. Either this or the sql-type must be available. The field-type
	 * is available if there is a corresponding column-name set on the holder.
	 */
	public FieldType getFieldType();
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy