org.h2.constant
Class ErrorCode

java.lang.Object
  extended by org.h2.constant.ErrorCode

public class ErrorCode
extends java.lang.Object

This class defines the error codes used for SQL exceptions.


Field Summary
static int ACCESS_DENIED_TO_CLASS_1
          The error with code 90134 is thrown when trying to load a Java class that is not part of the allowed classes.
static int ADMIN_RIGHTS_REQUIRED
          The error with code 90040 is thrown when a user that is not administrator tries to execute a statement that requires admin privileges.
static int AGGREGATE_NOT_FOUND_1
          The error with code 90132 is thrown when trying to drop a user-defined aggregate function that doesn't exist.
static int AMBIGUOUS_COLUMN_NAME_1
          The error with code 90059 is thrown when a query contains a column that could belong to multiple tables.
static int CAN_ONLY_ASSIGN_TO_VARIABLE_1
          The error with code 90137 is thrown when trying to assign a value to something that is not a variable.
static int CANNOT_CHANGE_SETTING_WHEN_OPEN_1
          The error with code 90133 is thrown when trying to change a specific database property while the database is already open.
static int CANNOT_DROP_2
          The error with code 90107 is thrown when trying to drop an object because another object would become invalid.
static int CANNOT_DROP_CURRENT_USER
          The error with code 90019 is thrown when trying to drop the current user.
static int CANNOT_DROP_LAST_COLUMN
          The error with code 90084 is thrown when trying to drop the last column of a table.
static int CANNOT_DROP_TABLE_1
          The error with code 90118 is thrown when trying to drop a table can not be dropped.
static int CANNOT_MIX_INDEXED_AND_UNINDEXED_PARAMS
          The error with code 90123 is thrown when trying mix regular parameters and indexed parameters in the same statement.
static int CANNOT_TRUNCATE_1
          The error with code 90106 is thrown when trying to truncate a table that can not be truncated.
static int CHECK_CONSTRAINT_VIOLATED_1
          The error with code 23000 is thrown when a check constraint is violated.
static int CLASS_NOT_FOUND_1
          The error with code 90086 is thrown when a class can not be loaded because it is not in the classpath or because a related class is not in the classpath.
static int CLUSTER_ERROR_DATABASE_RUNS_ALONE
          The error with code 90093 is thrown when trying to connect to a clustered database that runs in standalone mode.
static int CLUSTER_ERROR_DATABASE_RUNS_CLUSTERED_1
          The error with code 90094 is thrown when trying to connect to a clustered database that runs together with a different cluster node setting than what is used when trying to connect.
static int COLLATION_CHANGE_WITH_DATA_TABLE_1
          The error with code 90089 is thrown when trying to change the collation while there was already data in the database.
static int COLUMN_CONTAINS_NULL_VALUES_1
          The error with code 90081 is thrown when trying to alter a column to not allow NULL, if there is already data in the table where this column is NULL.
static int COLUMN_COUNT_DOES_NOT_MATCH
          The error with code 21002 is thrown when the number of columns does not match.
static int COLUMN_IS_PART_OF_INDEX_1
          The error with code 90075 is thrown when trying to alter a table and allow null for a column that is part of a primary key or hash index.
static int COLUMN_MAY_BE_REFERENCED_1
          The error with code 90083 is thrown when trying to drop a column that is part of a constraint.
static int COLUMN_MUST_NOT_BE_NULLABLE_1
          The error with code 90023 is thrown when trying to set a primary key on a nullable column.
static int COLUMN_NOT_FOUND_1
          The error with code 42122 is thrown when referencing an non-existing column.
static int COMMIT_ROLLBACK_NOT_ALLOWED
          The error with code 90058 is thrown when trying to call commit or rollback inside a trigger, or when trying to call a method inside a trigger that implicitly commits the current transaction, if an object is locked.
static int COMPRESSION_ERROR
          The error with code 90104 is thrown when the data can not be de-compressed.
static int CONCURRENT_UPDATE_1
          The error with code 90131 is thrown when using multi version concurrency control, and trying to update the same row from within two connections at the same time.
static int CONNECTION_BROKEN
          The error with code 90067 is thrown when the connection to the database is lost.
static int CONSTANT_ALREADY_EXISTS_1
          The error with code 90114 is thrown when trying to create a constant if a constant with this name already exists.
static int CONSTANT_NOT_FOUND_1
          The error with code 90115 is thrown when trying to drop a constant that does not exists.
static int CONSTRAINT_ALREADY_EXISTS_1
          The error with code 90045 is thrown when trying to create a constraint if an object with this name already exists.
static int CONSTRAINT_NOT_FOUND_1
          The error with code 90057 is thrown when trying to drop a constraint that does not exist.
static int DATA_CONVERSION_ERROR_1
          The error with code 90021 is thrown when trying to convert a value to a data type where the conversion is undefined, or when an error occurred trying to convert.
static int DATABASE_ALREADY_OPEN_1
          The error with code 90020 is thrown when trying to open a database in embedded mode if this database is already in use in another process (or in a different class loader).
static int DATABASE_CALLED_AT_SHUTDOWN
          The error with code 90121 is thrown when a database operation is started while the virtual machine exits (for example in a shutdown hook), or when the session is closed.
static int DATABASE_IS_IN_EXCLUSIVE_MODE
          The error with code 90135 is thrown when trying to open a connection to a database that is currently open in exclusive mode.
static int DATABASE_IS_NOT_PERSISTENT
          The error with code 90126 is thrown when trying to call the BACKUP statement for an in-memory database.
static int DATABASE_IS_READ_ONLY
          The error with code 90097 is thrown when trying to delete or update a database if it is open in read-only mode.
static int DATABASE_NOT_FOUND_1
          The error with code 90013 is thrown when trying to open a database that does not exist using the flag IFEXISTS=TRUE, or when trying to access a database object with a catalog name that does not match the database name.
static int DATE_CONSTANT_2
          The error with code 90009 is thrown when a text can not be converted to a date constant.
static int DEADLOCK_1
          The error with code 40001 is thrown when the database engine has detected a deadlock.
static int DESERIALIZATION_FAILED_1
          The error with code 90027 is thrown when an object could not be de-serialized.
static int DIVISION_BY_ZERO_1
          The error with code 22012 is thrown when trying to divide a value by zero.
static int DRIVER_VERSION_ERROR_2
          The error with code 90047 is thrown when trying to connect to a TCP server with an incompatible client.
static int DUPLICATE_COLUMN_NAME_1
          The error with code 42121 is thrown when trying to create a table or insert into a table and use the same column name twice.
static int DUPLICATE_KEY_1
          The error with code 23001 is thrown when trying to insert a row that would violate a unique index or primary key.
static int DUPLICATE_PROPERTY_1
          The error with code 90066 is thrown when the same property appears twice in the database URL or in the connection properties.
static int ERROR_ACCESSING_LINKED_TABLE_2
          The error with code 90111 is thrown when an exception occurred while accessing a linked table.
static int ERROR_CREATING_TRIGGER_OBJECT_3
          The error with code 90043 is thrown when there is an error initializing the trigger, for example because the class does not implement the Trigger interface.
static int ERROR_EXECUTING_TRIGGER_3
          The error with code 90044 is thrown when an exception or error occurred while calling the triggers fire method.
static int ERROR_OPENING_DATABASE_1
          The error with code 8000 is thrown when there was a problem trying to create a database lock.
static int ERROR_SETTING_DATABASE_EVENT_LISTENER_2
          The error with code 90099 is thrown when an error occurred trying to initialize the database event listener.
static int EXCEPTION_IN_FUNCTION
          The error with code 90105 is thrown when an exception occurred in a user-defined method.
static int EXCEPTION_OPENING_PORT_2
          The error with code 90061 is thrown when trying to start a server if a server is already running on the same port.
static int FEATURE_NOT_SUPPORTED_1
          The error with code 50100 is thrown when calling an unsupported JDBC method.
static int FILE_CORRUPTED_1
          The error with code 90030 is thrown when the database engine has detected a checksum mismatch in the data or index.
static int FILE_CREATION_FAILED_1
          The error with code 90062 is thrown when a directory or file could not be created.
static int FILE_DELETE_FAILED_1
          The error with code 90025 is thrown when a file could not be deleted, because it is still in use (only in Windows), or because an error occurred when deleting.
static int FILE_ENCRYPTION_ERROR_1
          The error with code 90049 is thrown when trying to open an encrypted database with the wrong file encryption password or algorithm.
static int FILE_NOT_FOUND_1
          The error with code 90124 is thrown when trying to access a file that doesn't exist.
static int FILE_RENAME_FAILED_2
          The error with code 90024 is thrown when a file could not be renamed.
static int FILE_VERSION_ERROR_1
          The error with code 90048 is thrown when the file header of a database files (*.db) does not match the expected version, or if it is corrupted.
static int FUNCTION_ALIAS_ALREADY_EXISTS_1
          The error with code 90076 is thrown when trying to create a function alias for a system function or for a function that is already defined.
static int FUNCTION_ALIAS_NOT_FOUND_1
          The error with code 90077 is thrown when trying to drop a system function or a function alias that does not exist.
static int FUNCTION_MUST_RETURN_RESULT_SET_1
          The error with code 90000 is thrown when a function that does not return a result set was used in the FROM clause.
static int FUNCTION_NOT_FOUND_1
          The error with code 90022 is thrown when trying to call a unknown function.
static int GENERAL_ERROR_1
          The error with code 50000 is thrown when something unexpected occurs, for example an internal stack overflow.
static int HEX_STRING_ODD_1
          The error with code 90003 is thrown when trying to convert a String to a binary value.
static int HEX_STRING_WRONG_1
          The error with code 90004 is thrown when trying to convert a text to binary, but the expression contains a non-hexadecimal character.
static int INDEX_ALREADY_EXISTS_1
          The error with code 42111 is thrown when trying to create an index if an index with the same name already exists.
static int INDEX_BELONGS_TO_CONSTRAINT_1
          The error with code 90085 is thrown when trying to manually drop an index that was generated by the system because of a unique constraint.
static int INDEX_NOT_FOUND_1
          The error with code 42112 is thrown when trying to drop or reference an index that does not exist.
static int INVALID_CLASS_2
          The error with code 90125 is thrown when PreparedStatement.setBigDecimal is called with object that extends the class BigDecimal, and the system property h2.allowBigDecimalExtensions is not set.
static int INVALID_DATABASE_NAME_1
          The error with code 90138 is thrown when trying to open a persistent database using an incorrect database name.
static int INVALID_PARAMETER_COUNT_2
          The error with code 7001 is thrown when trying to call a function with the wrong number of parameters.
static int INVALID_USE_OF_AGGREGATE_FUNCTION_1
          The error with code 90054 is thrown when an aggregate function is used where it is not allowed.
static int INVALID_VALUE_2
          The error with code 90008 is thrown when trying to use a value that is not valid for the given operation.
static int IO_EXCEPTION_1
          The error with code 90028 is thrown when an input / output error occurred.
static int IO_EXCEPTION_2
          The error with code 90031 is thrown when an input / output error occurred.
static int LIKE_ESCAPE_ERROR_1
          The error with code 22025 is thrown when using an invalid escape character sequence for LIKE or REGEXP.
static int LITERALS_ARE_NOT_ALLOWED
          The error with code 90116 is thrown when trying use a literal in a SQL statement if literals are disabled.
static int LOCK_TIMEOUT_1
          The error with code 50200 is thrown when another connection locked an object longer than the lock timeout set for this connection, or when a deadlock occurred.
static int METHOD_NOT_ALLOWED_FOR_PREPARED_STATEMENT
          The error with code 90130 is thrown when an execute method of PreparedStatement was called with a SQL statement.
static int METHOD_NOT_ALLOWED_FOR_QUERY
          The error with code 90001 is thrown when Statement.executeUpdate() was called for a SELECT statement.
static int METHOD_NOT_FOUND_1
          The error with code 90087 is thrown when the specified method was not found in the class.
static int METHOD_ONLY_ALLOWED_FOR_QUERY
          The error with code 90002 is thrown when Statement.executeQuery() was called for a statement that does not return a result set (for example, an UPDATE statement).
static int METHODS_MUST_HAVE_DIFFERENT_PARAMETER_COUNTS_2
          The error with code 90073 is thrown when trying to create an alias for a Java method, if two methods exists in this class that have this name and the same number of parameters.
static int MUST_GROUP_BY_COLUMN_1
          The error with code 90016 is thrown when a column was used in the expression list or the order by clause of a group or aggregate query, and that column is not in the GROUP BY clause.
static int NO_DATA_AVAILABLE
          The error with code 2000 is thrown when the result set is positioned before the first or after the last row, or not on a valid row for the given operation.
static int NO_DEFAULT_SET_1
          The error with code 90056 is thrown when updating or deleting from a table with a foreign key constraint that should set the default value, but there is no default value defined.
static int NO_DISK_SPACE_AVAILABLE
          The error with code 90100 is thrown when there is no more space available on the device where the database files are stored.
static int NOT_ENOUGH_RIGHTS_FOR_1
          The error with code 90096 is thrown when trying to perform an operation with a non-admin user if the user does not have enough rights.
static int NOT_ON_UPDATABLE_ROW
          The error with code 90029 is thrown when calling ResultSet.deleteRow(), insertRow(), or updateRow() when the current row is not updatable.
static int NULL_NOT_ALLOWED
          The error with code 90006 is thrown when trying to insert NULL into a column that does not allow NULL.
static int NUMERIC_VALUE_OUT_OF_RANGE
          The error with code 22003 is thrown when a value is out of range when converting to another data type.
static int OBJECT_CLOSED
          The error with code 90007 is thrown when trying to call a JDBC method on an object that has been closed.
static int OPERATION_NOT_SUPPORTED_WITH_VIEWS_2
          The error with code 90122 is thrown when trying to altering, adding or dropping columns of a table that has views.
static int ORDER_BY_NOT_IN_RESULT
          The error with code 90068 is thrown when the given expression that is used in the ORDER BY is not in the result list.
static int OUT_OF_MEMORY
          The error with code 90108 is thrown when not enough heap memory was available.
static int OVERFLOW_FOR_TYPE_1
          The error with code 90110 is thrown when the result of the calculation does not fit in the given data type.
static int PARAMETER_NOT_SET_1
          The error with code 90012 is thrown when trying to execute a statement with an parameter.
static int PARSE_ERROR_1
          The error with code 90014 is thrown when trying to parse a date with an unsupported format string, or when the date can not be parsed.
static int PUBLIC_STATIC_JAVA_METHOD_NOT_FOUND_1
          The error with code 90139 is thrown when the specified public static Java method was not found in the class.
static int REFERENTIAL_INTEGRITY_VIOLATED_CHILD_EXISTS_1
          The error with code 23003 is thrown when trying to delete or update a row when this would violate a referential constraint, because there is a child row that would become an orphan.
static int REFERENTIAL_INTEGRITY_VIOLATED_PARENT_MISSING_1
          The error with code 23002 is thrown when trying to insert or update a row that would violate a referential constraint, because the referenced row does not exist.
static int REMOTE_CONNECTION_NOT_ALLOWED
          The error with code 90117 is thrown when trying to connect to a TCP server from another machine, if remote connections are not allowed.
static int RESULT_SET_NOT_SCROLLABLE
          The error with code 90128 is thrown when trying to call a method of the ResultSet that is only supported for scrollable result sets, and the result set is not scrollable.
static int RESULT_SET_NOT_UPDATABLE
          The error with code 90127 is thrown when trying to update or delete a row in a result set if the result set is not updatable.
static int RESULT_SET_READONLY
          The error with code 90140 is thrown when trying to update or delete a row in a result set if the statement was not created with updatable concurrency.
static int ROLE_ALREADY_EXISTS_1
          The error with code 90069 is thrown when trying to create a role if an object with this name already exists.
static int ROLE_ALREADY_GRANTED_1
          The error with code 90074 is thrown when trying to grant a role that has already been granted.
static int ROLE_CAN_NOT_BE_DROPPED_1
          The error with code 90091 is thrown when trying to drop the role PUBLIC.
static int ROLE_NOT_FOUND_1
          The error with code 90070 is thrown when trying to drop or grant a role that does not exists.
static int ROLES_AND_RIGHT_CANNOT_BE_MIXED
          The error with code 90072 is thrown when trying to grant or revoke if no role or user with that name exists.
static int ROW_NOT_FOUND_WHEN_DELETING_1
          The error with code 90112 is thrown when a row was deleted twice while locking was disabled.
static int SAVEPOINT_IS_INVALID_1
          The error with code 90063 is thrown when trying to rollback to a savepoint that is not defined.
static int SAVEPOINT_IS_NAMED
          The error with code 90065 is thrown when Savepoint.getSavepointId() is called on a named savepoint.
static int SAVEPOINT_IS_UNNAMED
          The error with code 90064 is thrown when Savepoint.getSavepointName() is called on an unnamed savepoint.
static int SCALAR_SUBQUERY_CONTAINS_MORE_THAN_ONE_ROW
          The error with code 90053 is thrown when a subquery that is used as a value contains more than one row.
static int SCHEMA_ALREADY_EXISTS_1
          The error with code 90078 is thrown when trying to create a schema if an object with this name already exists.
static int SCHEMA_CAN_NOT_BE_DROPPED_1
          The error with code 90090 is thrown when trying to drop a schema that may not be dropped (the schema PUBLIC and the schema INFORMATION_SCHEMA).
static int SCHEMA_NAME_MUST_MATCH
          The error with code 90080 is thrown when trying to rename a object to a different schema, or when trying to create a related object in another schema.
static int SCHEMA_NOT_FOUND_1
          The error with code 90079 is thrown when trying to drop a schema that does not exist.
static int SECOND_PRIMARY_KEY
          The error with code 90017 is thrown when trying to define a second primary key constraint for this table.
static int SEQUENCE_ALREADY_EXISTS_1
          The error with code 90035 is thrown when trying to create a sequence if a sequence with this name already exists.
static int SEQUENCE_BELONGS_TO_A_TABLE_1
          The error with code 90082 is thrown when trying to drop a system generated sequence.
static int SEQUENCE_NOT_FOUND_1
          The error with code 90036 is thrown when trying to access a sequence that does not exist.
static int SERIALIZATION_FAILED_1
          The error with code 90026 is thrown when an object could not be serialized.
static int SIMULATED_POWER_OFF
          The error with code 90098 is thrown when the self-destruction counter has reached zero.
static int STATEMENT_WAS_CANCELED
          The error with code 90051 is thrown when a statement was canceled using Statement.cancel() or when the query timeout has been reached.
static int STRING_FORMAT_ERROR_1
          The error with code 90095 is thrown when calling the method STRINGDECODE with an invalid escape sequence.
static int SUBQUERY_IS_NOT_SINGLE_COLUMN
          The error with code 90052 is thrown when a subquery that is used as a value contains more than one column.
static int SUM_OR_AVG_ON_WRONG_DATATYPE_1
          The error with code 90015 is thrown when using an aggregate function with a data type that is not supported.
static int SYNTAX_ERROR_1
          The error with code 42000 is thrown when trying to execute an invalid SQL statement.
static int SYNTAX_ERROR_2
          The error with code 42001 is thrown when trying to execute an invalid SQL statement.
static int TABLE_OR_VIEW_ALREADY_EXISTS_1
          The error with code 42101 is thrown when trying to create a table or view if an object with this name already exists.
static int TABLE_OR_VIEW_NOT_FOUND_1
          The error with code 42102 is thrown when trying to query, modify or drop a table or view that does not exists in this schema and database.
static int TIME_CONSTANT_2
          The error with code 90010 is thrown when a text can not be converted to a time constant.
static int TIMESTAMP_CONSTANT_2
          The error with code 90011 is thrown when a text can not be converted to a timestamp constant.
static int TRACE_CONNECTION_NOT_CLOSED
          The error with code 90018 is thrown when the connection was opened, but never closed.
static int TRACE_FILE_ERROR_2
          The error with code 90034 is thrown when writing to the trace file failed, for example because the there is an I/O exception.
static int TRANSACTION_NOT_FOUND_1
          The error with code 90129 is thrown when trying to commit a transaction that doesn't exist.
static int TRIGGER_ALREADY_EXISTS_1
          The error with code 90041 is thrown when trying to create a trigger and there is already a trigger with that name.
static int TRIGGER_NOT_FOUND_1
          The error with code 90042 is thrown when trying to drop a trigger that does not exist.
static int UNKNOWN_DATA_TYPE_1
          The error with code 50004 is thrown when creating a table with an unsupported data type, or when the data type is unknown because parameters are used.
static int UNKNOWN_MODE_1
          The error with code 90088 is thrown when trying to switch to an unknown mode.
static int UNSUPPORTED_CIPHER
          The error with code 90055 is thrown when trying to open a database with an unsupported cipher algorithm.
static int UNSUPPORTED_COMPRESSION_ALGORITHM_1
          The error with code 90103 is thrown when trying to use an unsupported compression algorithm.
static int UNSUPPORTED_COMPRESSION_OPTIONS_1
          The error with code 90102 is thrown when trying to use unsupported options for the given compression algorithm.
static int UNSUPPORTED_JAVA_VERSION
          The error with code 90092 is thrown when the source code is not compiled for the Java platform used.
static int UNSUPPORTED_LOCK_METHOD_1
          The error with code 90060 is thrown when trying to use a file locking mechanism that is not supported.
static int UNSUPPORTED_OUTER_JOIN_CONDITION_1
          The error with code 90136 is thrown when executing a query that used an unsupported outer join condition.
static int UNSUPPORTED_SETTING_1
          The error with code 90113 is thrown when the database URL contains unsupported settings.
static int URL_FORMAT_ERROR_2
          The error with code 90046 is thrown when trying to open a connection to a database using an unsupported URL format.
static int USER_ALREADY_EXISTS_1
          The error with code 90033 is thrown when trying to create a user or role if a user with this name already exists.
static int USER_DATA_TYPE_ALREADY_EXISTS_1
          The error with code 90119 is thrown when trying to create a domain if an object with this name already exists, or when trying to overload a built-in data type.
static int USER_DATA_TYPE_NOT_FOUND_1
          The error with code 90120 is thrown when trying to drop a domain that doesn't exists.
static int USER_NOT_FOUND_1
          The error with code 90032 is thrown when trying to drop or alter a user that does not exist.
static int USER_OR_ROLE_NOT_FOUND_1
          The error with code 90071 is thrown when trying to grant or revoke if no role or user with that name exists.
static int VALUE_TOO_LARGE_FOR_PRECISION_1
          The error with code 90039 is thrown when trying to convert a decimal value to lower precision if the value is out of range for this precision.
static int VALUE_TOO_LONG_2
          The error with code 90005 is thrown when trying to insert a value that is too long for the column.
static int VIEW_ALREADY_EXISTS_1
          The error with code 90038 is thrown when trying to create a view if a view with this name already exists.
static int VIEW_IS_INVALID_2
          The error with code 90109 is thrown when trying to run a query against an invalid view.
static int VIEW_NOT_FOUND_1
          The error with code 90037 is thrown when trying to drop or alter a view that does not exist.
static int WRONG_PASSWORD_FORMAT
          The error with code 90050 is thrown when trying to open an encrypted database, but not separating the file password from the user password.
static int WRONG_USER_OR_PASSWORD
          The error with code 8004 is thrown when there is no such user registered in the database, when the user password does not match, or when the database encryption password does not match (if database encryption is used).
static int WRONG_XID_FORMAT_1
          The error with code 90101 is thrown when the XA API detected unsupported transaction names.
 
Method Summary
static java.lang.String getState(int errorCode)
          INTERNAL
static boolean isCommon(int errorCode)
          INTERNAL
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

NO_DATA_AVAILABLE

public static final int NO_DATA_AVAILABLE
The error with code 2000 is thrown when the result set is positioned before the first or after the last row, or not on a valid row for the given operation. Example of wrong usage:
 ResultSet rs = stat.executeQuery("SELECT * FROM DUAL");
 rs.getString(1);
 
Correct:
 ResultSet rs = stat.executeQuery("SELECT * FROM DUAL");
 rs.next();
 rs.getString(1);
 

See Also:
Constant Field Values

INVALID_PARAMETER_COUNT_2

public static final int INVALID_PARAMETER_COUNT_2
The error with code 7001 is thrown when trying to call a function with the wrong number of parameters. Example:
 CALL ABS(1, 2)
 

See Also:
Constant Field Values

ERROR_OPENING_DATABASE_1

public static final int ERROR_OPENING_DATABASE_1
The error with code 8000 is thrown when there was a problem trying to create a database lock. See the message and cause for details.

See Also:
Constant Field Values

WRONG_USER_OR_PASSWORD

public static final int WRONG_USER_OR_PASSWORD
The error with code 8004 is thrown when there is no such user registered in the database, when the user password does not match, or when the database encryption password does not match (if database encryption is used).

See Also:
Constant Field Values

COLUMN_COUNT_DOES_NOT_MATCH

public static final int COLUMN_COUNT_DOES_NOT_MATCH
The error with code 21002 is thrown when the number of columns does not match. Possible reasons are: for an INSERT or MERGE statement, the column count does not match the table or the column list specified. For a SELECT UNION statement, both queries return a different number of columns. For a constraint, the number of referenced and referencing columns does not match. Example:
 CREATE TABLE TEST(ID INT, NAME VARCHAR);
 INSERT INTO TEST VALUES('Hello');
 

See Also:
Constant Field Values

NUMERIC_VALUE_OUT_OF_RANGE

public static final int NUMERIC_VALUE_OUT_OF_RANGE
The error with code 22003 is thrown when a value is out of range when converting to another data type. Example:
 CALL CAST(1000000 AS TINYINT);
 

See Also:
Constant Field Values

DIVISION_BY_ZERO_1

public static final int DIVISION_BY_ZERO_1
The error with code 22012 is thrown when trying to divide a value by zero. Example:
 CALL 1/0;
 

See Also:
Constant Field Values

LIKE_ESCAPE_ERROR_1

public static final int LIKE_ESCAPE_ERROR_1
The error with code 22025 is thrown when using an invalid escape character sequence for LIKE or REGEXP. The default escape character is '\'. The escape character is required when searching for the characters '%', '_' and the escape character itself. That means if you want to search for the text '10%', you need to use LIKE '10\%'. If you want to search for 'C:\temp' you need to use 'C:\\temp'. The escape character can be changed using the ESCAPE clause as in LIKE '10+%' ESCAPE '+'. Example of wrong usage:
 CALL 'C:\temp' LIKE 'C:\temp';
 CALL '1+1' LIKE '1+1' ESCAPE '+';
 
Correct:
 CALL 'C:\temp' LIKE 'C:\\temp';
 CALL '1+1' LIKE '1++1' ESCAPE '+';
 

See Also:
Constant Field Values

CHECK_CONSTRAINT_VIOLATED_1

public static final int CHECK_CONSTRAINT_VIOLATED_1
The error with code 23000 is thrown when a check constraint is violated. Example:
 CREATE TABLE TEST(ID INT CHECK ID>0);
 INSERT INTO TEST VALUES(0);
 

See Also:
Constant Field Values

DUPLICATE_KEY_1

public static final int DUPLICATE_KEY_1
The error with code 23001 is thrown when trying to insert a row that would violate a unique index or primary key. Example:
 CREATE TABLE TEST(ID INT PRIMARY KEY);
 INSERT INTO TEST VALUES(1);
 INSERT INTO TEST VALUES(1);
 

See Also:
Constant Field Values

REFERENTIAL_INTEGRITY_VIOLATED_PARENT_MISSING_1

public static final int REFERENTIAL_INTEGRITY_VIOLATED_PARENT_MISSING_1
The error with code 23002 is thrown when trying to insert or update a row that would violate a referential constraint, because the referenced row does not exist. Example:
 CREATE TABLE PARENT(ID INT);
 CREATE TABLE CHILD(P_ID INT REFERENCES PARENT(ID));
 INSERT INTO CHILD VALUES(1);
 

See Also:
Constant Field Values

REFERENTIAL_INTEGRITY_VIOLATED_CHILD_EXISTS_1

public static final int REFERENTIAL_INTEGRITY_VIOLATED_CHILD_EXISTS_1
The error with code 23003 is thrown when trying to delete or update a row when this would violate a referential constraint, because there is a child row that would become an orphan. Example:
 CREATE TABLE PARENT(ID INT);
 CREATE TABLE CHILD(P_ID INT REFERENCES PARENT(ID));
 INSERT INTO PARENT VALUES(1);
 INSERT INTO CHILD VALUES(1);
 DELETE FROM PARENT;
 

See Also:
Constant Field Values

DEADLOCK_1

public static final int DEADLOCK_1
The error with code 40001 is thrown when the database engine has detected a deadlock. The transaction of this session has been rolled back to solve the problem. A deadlock occurs when a session tries to lock a table another session has locked, while the other session wants to lock a table the first session has locked. As an example, session 1 has locked table A, while session 2 has locked table B. If session 1 now tries to lock table B and session 2 tries to lock table A, a deadlock has occurred. Deadlocks that involve more than two sessions are also possible. To solve deadlock problems, an application should lock tables always in the same order, such as always lock table A before locking table B. For details, see Wikipedia Deadlock.

See Also:
Constant Field Values

SYNTAX_ERROR_1

public static final int SYNTAX_ERROR_1
The error with code 42000 is thrown when trying to execute an invalid SQL statement. Example:
 CREATE ALIAS REMAINDER FOR "IEEEremainder";
 

See Also:
Constant Field Values

SYNTAX_ERROR_2

public static final int SYNTAX_ERROR_2
The error with code 42001 is thrown when trying to execute an invalid SQL statement. Example:
 CREATE TABLE TEST(ID INT);
 INSERT INTO TEST(1);
 

See Also:
Constant Field Values

TABLE_OR_VIEW_ALREADY_EXISTS_1

public static final int TABLE_OR_VIEW_ALREADY_EXISTS_1
The error with code 42101 is thrown when trying to create a table or view if an object with this name already exists. Example:
 CREATE TABLE TEST(ID INT);
 CREATE TABLE TEST(ID INT PRIMARY KEY);
 

See Also:
Constant Field Values

TABLE_OR_VIEW_NOT_FOUND_1

public static final int TABLE_OR_VIEW_NOT_FOUND_1
The error with code 42102 is thrown when trying to query, modify or drop a table or view that does not exists in this schema and database. A common cause is that the wrong database was opened. Example:
 SELECT * FROM ABC;
 

See Also:
Constant Field Values

INDEX_ALREADY_EXISTS_1

public static final int INDEX_ALREADY_EXISTS_1
The error with code 42111 is thrown when trying to create an index if an index with the same name already exists. Example:
 CREATE TABLE TEST(ID INT, NAME VARCHAR);
 CREATE INDEX IDX_ID ON TEST(ID);
 CREATE TABLE ADDRESS(ID INT);
 CREATE INDEX IDX_ID ON ADDRESS(ID);
 

See Also:
Constant Field Values

INDEX_NOT_FOUND_1

public static final int INDEX_NOT_FOUND_1
The error with code 42112 is thrown when trying to drop or reference an index that does not exist. Example:
 DROP INDEX ABC;
 

See Also:
Constant Field Values

DUPLICATE_COLUMN_NAME_1

public static final int DUPLICATE_COLUMN_NAME_1
The error with code 42121 is thrown when trying to create a table or insert into a table and use the same column name twice. Example:
 CREATE TABLE TEST(ID INT, ID INT);
 

See Also:
Constant Field Values

COLUMN_NOT_FOUND_1

public static final int COLUMN_NOT_FOUND_1
The error with code 42122 is thrown when referencing an non-existing column. Example:
 CREATE TABLE TEST(ID INT);
 SELECT NAME FROM TEST;
 

See Also:
Constant Field Values

GENERAL_ERROR_1

public static final int GENERAL_ERROR_1
The error with code 50000 is thrown when something unexpected occurs, for example an internal stack overflow. For details about the problem, see the cause of the exception in the stack trace.

See Also:
Constant Field Values

UNKNOWN_DATA_TYPE_1

public static final int UNKNOWN_DATA_TYPE_1
The error with code 50004 is thrown when creating a table with an unsupported data type, or when the data type is unknown because parameters are used. Example:
 CREATE TABLE TEST(ID VERYSMALLINT);
 

See Also:
Constant Field Values

FEATURE_NOT_SUPPORTED_1

public static final int FEATURE_NOT_SUPPORTED_1
The error with code 50100 is thrown when calling an unsupported JDBC method. See the stack trace for details.

See Also:
Constant Field Values

LOCK_TIMEOUT_1

public static final int LOCK_TIMEOUT_1
The error with code 50200 is thrown when another connection locked an object longer than the lock timeout set for this connection, or when a deadlock occurred. Example:
 CREATE TABLE TEST(ID INT);
 -- connection 1:
 SET AUTOCOMMIT FALSE;
 INSERT INTO TEST VALUES(1);
 -- connection 2:
 SET AUTOCOMMIT FALSE;
 INSERT INTO TEST VALUES(1);
 

See Also:
Constant Field Values

FUNCTION_MUST_RETURN_RESULT_SET_1

public static final int FUNCTION_MUST_RETURN_RESULT_SET_1
The error with code 90000 is thrown when a function that does not return a result set was used in the FROM clause. Example:
 SELECT * FROM SIN(1);
 

See Also:
Constant Field Values

METHOD_NOT_ALLOWED_FOR_QUERY

public static final int METHOD_NOT_ALLOWED_FOR_QUERY
The error with code 90001 is thrown when Statement.executeUpdate() was called for a SELECT statement. This is not allowed according to the JDBC specs.

See Also:
Constant Field Values

METHOD_ONLY_ALLOWED_FOR_QUERY

public static final int METHOD_ONLY_ALLOWED_FOR_QUERY
The error with code 90002 is thrown when Statement.executeQuery() was called for a statement that does not return a result set (for example, an UPDATE statement). This is not allowed according to the JDBC specs.

See Also:
Constant Field Values

HEX_STRING_ODD_1

public static final int HEX_STRING_ODD_1
The error with code 90003 is thrown when trying to convert a String to a binary value. Two hex digits per byte are required. Example of wrong usage:
 CALL X'00023';
 Hexadecimal string with odd number of characters: 00023
 
Correct:
 CALL X'000023';
 

See Also:
Constant Field Values

HEX_STRING_WRONG_1

public static final int HEX_STRING_WRONG_1
The error with code 90004 is thrown when trying to convert a text to binary, but the expression contains a non-hexadecimal character. Example:
 CALL X'ABCDEFGH';
 CALL CAST('ABCDEFGH' AS BINARY);
 
Conversion from text to binary is supported, but the text must represent the hexadecimal encoded bytes.

See Also:
Constant Field Values

VALUE_TOO_LONG_2

public static final int VALUE_TOO_LONG_2
The error with code 90005 is thrown when trying to insert a value that is too long for the column. Example:
 CREATE TABLE TEST(ID INT, NAME VARCHAR(2));
 INSERT INTO TEST VALUES(1, 'Hello');
 

See Also:
Constant Field Values

NULL_NOT_ALLOWED

public static final int NULL_NOT_ALLOWED
The error with code 90006 is thrown when trying to insert NULL into a column that does not allow NULL. Example:
 CREATE TABLE TEST(ID INT, NAME VARCHAR NOT NULL);
 INSERT INTO TEST(ID) VALUES(1);
 

See Also:
Constant Field Values

OBJECT_CLOSED

public static final int OBJECT_CLOSED
The error with code 90007 is thrown when trying to call a JDBC method on an object that has been closed.

See Also:
Constant Field Values

INVALID_VALUE_2

public static final int INVALID_VALUE_2
The error with code 90008 is thrown when trying to use a value that is not valid for the given operation. Example:
 CREATE SEQUENCE TEST INCREMENT 0;
 

See Also:
Constant Field Values

DATE_CONSTANT_2

public static final int DATE_CONSTANT_2
The error with code 90009 is thrown when a text can not be converted to a date constant. Example:
 CALL DATE '2007-January-01';
 

See Also:
Constant Field Values

TIME_CONSTANT_2

public static final int TIME_CONSTANT_2
The error with code 90010 is thrown when a text can not be converted to a time constant. Example:
 CALL TIME '14:61:00';
 

See Also:
Constant Field Values

TIMESTAMP_CONSTANT_2

public static final int TIMESTAMP_CONSTANT_2
The error with code 90011 is thrown when a text can not be converted to a timestamp constant. Example:
 CALL TIMESTAMP '2001-02-30 12:00:00';
 

See Also:
Constant Field Values

PARAMETER_NOT_SET_1

public static final int PARAMETER_NOT_SET_1
The error with code 90012 is thrown when trying to execute a statement with an parameter. Example:
 CALL SIN(?);
 

See Also:
Constant Field Values

DATABASE_NOT_FOUND_1

public static final int DATABASE_NOT_FOUND_1
The error with code 90013 is thrown when trying to open a database that does not exist using the flag IFEXISTS=TRUE, or when trying to access a database object with a catalog name that does not match the database name. Example:
 CREATE TABLE TEST(ID INT);
 SELECT XYZ.PUBLIC.TEST.ID FROM TEST;
 

See Also:
Constant Field Values

PARSE_ERROR_1

public static final int PARSE_ERROR_1
The error with code 90014 is thrown when trying to parse a date with an unsupported format string, or when the date can not be parsed. Example:
 CALL PARSEDATETIME('2001 January', 'yyyy mm');
 

See Also:
Constant Field Values

SUM_OR_AVG_ON_WRONG_DATATYPE_1

public static final int SUM_OR_AVG_ON_WRONG_DATATYPE_1
The error with code 90015 is thrown when using an aggregate function with a data type that is not supported. Example:
 SELECT SUM('Hello') FROM DUAL;
 

See Also:
Constant Field Values

MUST_GROUP_BY_COLUMN_1

public static final int MUST_GROUP_BY_COLUMN_1
The error with code 90016 is thrown when a column was used in the expression list or the order by clause of a group or aggregate query, and that column is not in the GROUP BY clause. Example of wrong usage:
 CREATE TABLE TEST(ID INT, NAME VARCHAR);
 INSERT INTO TEST VALUES(1, 'Hello'), (2, 'World');
 SELECT ID, MAX(NAME) FROM TEST;
 Column ID must be in the GROUP BY list.
 
Correct:
 SELECT ID, MAX(NAME) FROM TEST GROUP BY ID;
 

See Also:
Constant Field Values

SECOND_PRIMARY_KEY

public static final int SECOND_PRIMARY_KEY
The error with code 90017 is thrown when trying to define a second primary key constraint for this table. Example:
 CREATE TABLE TEST(ID INT PRIMARY KEY, NAME VARCHAR);
 ALTER TABLE TEST ADD CONSTRAINT PK PRIMARY KEY(NAME);
 

See Also:
Constant Field Values

TRACE_CONNECTION_NOT_CLOSED

public static final int TRACE_CONNECTION_NOT_CLOSED
The error with code 90018 is thrown when the connection was opened, but never closed. In the finalizer of the connection, this forgotten close was detected and the connection was closed automatically, but relying on the finalizer is not good practice as it is not guaranteed and behavior is virtual machine dependent. The application should close the connection. This exception only appears in the .trace.db file. Example of wrong usage:
 Connection conn;
 conn = DriverManager.getConnection("jdbc:h2:˜/test");
 conn = null;
 The connection was not closed by the application and is
 garbage collected
 
Correct:
 conn.close();
 

See Also:
Constant Field Values

CANNOT_DROP_CURRENT_USER

public static final int CANNOT_DROP_CURRENT_USER
The error with code 90019 is thrown when trying to drop the current user. Example:
 DROP USER SA;
 

See Also:
Constant Field Values

DATABASE_ALREADY_OPEN_1

public static final int DATABASE_ALREADY_OPEN_1
The error with code 90020 is thrown when trying to open a database in embedded mode if this database is already in use in another process (or in a different class loader). Multiple connections to the same database are supported in the following cases: The mixed mode is also supported. This mode requires to start a server in the same process where the database is open in embedded mode.

See Also:
Constant Field Values

DATA_CONVERSION_ERROR_1

public static final int DATA_CONVERSION_ERROR_1
The error with code 90021 is thrown when trying to convert a value to a data type where the conversion is undefined, or when an error occurred trying to convert. Example:
 CALL CAST(DATE '2001-01-01' AS BOOLEAN);
 CALL CAST('CHF 99.95' AS INT);
 

See Also:
Constant Field Values

FUNCTION_NOT_FOUND_1

public static final int FUNCTION_NOT_FOUND_1
The error with code 90022 is thrown when trying to call a unknown function. Example:
 CALL SPECIAL_SIN(10);
 

See Also:
Constant Field Values

COLUMN_MUST_NOT_BE_NULLABLE_1

public static final int COLUMN_MUST_NOT_BE_NULLABLE_1
The error with code 90023 is thrown when trying to set a primary key on a nullable column. Example:
 CREATE TABLE TEST(ID INT, NAME VARCHAR);
 ALTER TABLE TEST ADD CONSTRAINT PK PRIMARY KEY(ID);
 

See Also:
Constant Field Values

FILE_RENAME_FAILED_2

public static final int FILE_RENAME_FAILED_2
The error with code 90024 is thrown when a file could not be renamed.

See Also:
Constant Field Values

FILE_DELETE_FAILED_1

public static final int FILE_DELETE_FAILED_1
The error with code 90025 is thrown when a file could not be deleted, because it is still in use (only in Windows), or because an error occurred when deleting.

See Also:
Constant Field Values

SERIALIZATION_FAILED_1

public static final int SERIALIZATION_FAILED_1
The error with code 90026 is thrown when an object could not be serialized.

See Also:
Constant Field Values

DESERIALIZATION_FAILED_1

public static final int DESERIALIZATION_FAILED_1
The error with code 90027 is thrown when an object could not be de-serialized.

See Also:
Constant Field Values

IO_EXCEPTION_1

public static final int IO_EXCEPTION_1
The error with code 90028 is thrown when an input / output error occurred. For more information, see the root cause of the exception.

See Also:
Constant Field Values

NOT_ON_UPDATABLE_ROW

public static final int NOT_ON_UPDATABLE_ROW
The error with code 90029 is thrown when calling ResultSet.deleteRow(), insertRow(), or updateRow() when the current row is not updatable. Example:
 ResultSet rs = stat.executeQuery("SELECT * FROM TEST");
 rs.next();
 rs.insertRow();
 

See Also:
Constant Field Values

FILE_CORRUPTED_1

public static final int FILE_CORRUPTED_1
The error with code 90030 is thrown when the database engine has detected a checksum mismatch in the data or index. To solve this problem, restore a backup or use the Recovery tool (org.h2.tools.Recover).

See Also:
Constant Field Values

IO_EXCEPTION_2

public static final int IO_EXCEPTION_2
The error with code 90031 is thrown when an input / output error occurred. For more information, see the root cause of the exception.

See Also:
Constant Field Values

USER_NOT_FOUND_1

public static final int USER_NOT_FOUND_1
The error with code 90032 is thrown when trying to drop or alter a user that does not exist. Example:
 DROP USER TEST_USER;
 

See Also:
Constant Field Values

USER_ALREADY_EXISTS_1

public static final int USER_ALREADY_EXISTS_1
The error with code 90033 is thrown when trying to create a user or role if a user with this name already exists. Example:
 CREATE USER TEST_USER;
 CREATE USER TEST_USER;
 

See Also:
Constant Field Values

TRACE_FILE_ERROR_2

public static final int TRACE_FILE_ERROR_2
The error with code 90034 is thrown when writing to the trace file failed, for example because the there is an I/O exception. This message is printed to System.out, but only once.

See Also:
Constant Field Values

SEQUENCE_ALREADY_EXISTS_1

public static final int SEQUENCE_ALREADY_EXISTS_1
The error with code 90035 is thrown when trying to create a sequence if a sequence with this name already exists. Example:
 CREATE SEQUENCE TEST_SEQ;
 CREATE SEQUENCE TEST_SEQ;
 

See Also:
Constant Field Values

SEQUENCE_NOT_FOUND_1

public static final int SEQUENCE_NOT_FOUND_1
The error with code 90036 is thrown when trying to access a sequence that does not exist. Example:
 SELECT NEXT VALUE FOR SEQUENCE XYZ;
 

See Also:
Constant Field Values

VIEW_NOT_FOUND_1

public static final int VIEW_NOT_FOUND_1
The error with code 90037 is thrown when trying to drop or alter a view that does not exist. Example:
 DROP VIEW XYZ;
 

See Also:
Constant Field Values

VIEW_ALREADY_EXISTS_1

public static final int VIEW_ALREADY_EXISTS_1
The error with code 90038 is thrown when trying to create a view if a view with this name already exists. Example:
 CREATE VIEW DUMMY AS SELECT * FROM DUAL;
 CREATE VIEW DUMMY AS SELECT * FROM DUAL;
 

See Also:
Constant Field Values

VALUE_TOO_LARGE_FOR_PRECISION_1

public static final int VALUE_TOO_LARGE_FOR_PRECISION_1
The error with code 90039 is thrown when trying to convert a decimal value to lower precision if the value is out of range for this precision. Example:
 SELECT * FROM TABLE(X DECIMAL(2, 2) = (123.34));
 

See Also:
Constant Field Values

ADMIN_RIGHTS_REQUIRED

public static final int ADMIN_RIGHTS_REQUIRED
The error with code 90040 is thrown when a user that is not administrator tries to execute a statement that requires admin privileges.

See Also:
Constant Field Values

TRIGGER_ALREADY_EXISTS_1

public static final int TRIGGER_ALREADY_EXISTS_1
The error with code 90041 is thrown when trying to create a trigger and there is already a trigger with that name.
 CREATE TABLE TEST(ID INT);
 CREATE TRIGGER TRIGGER_A AFTER INSERT ON TEST
      CALL "org.h2.samples.TriggerSample$MyTrigger";
 CREATE TRIGGER TRIGGER_A AFTER INSERT ON TEST
      CALL "org.h2.samples.TriggerSample$MyTrigger";
 

See Also:
Constant Field Values

TRIGGER_NOT_FOUND_1

public static final int TRIGGER_NOT_FOUND_1
The error with code 90042 is thrown when trying to drop a trigger that does not exist. Example:
 DROP TRIGGER TRIGGER_XYZ;
 

See Also:
Constant Field Values

ERROR_CREATING_TRIGGER_OBJECT_3

public static final int ERROR_CREATING_TRIGGER_OBJECT_3
The error with code 90043 is thrown when there is an error initializing the trigger, for example because the class does not implement the Trigger interface. See the root cause for details. Example:
 CREATE TABLE TEST(ID INT);
 CREATE TRIGGER TRIGGER_A AFTER INSERT ON TEST
      CALL "java.lang.String";
 

See Also:
Constant Field Values

ERROR_EXECUTING_TRIGGER_3

public static final int ERROR_EXECUTING_TRIGGER_3
The error with code 90044 is thrown when an exception or error occurred while calling the triggers fire method. See the root cause for details.

See Also:
Constant Field Values

CONSTRAINT_ALREADY_EXISTS_1

public static final int CONSTRAINT_ALREADY_EXISTS_1
The error with code 90045 is thrown when trying to create a constraint if an object with this name already exists. Example:
 CREATE TABLE TEST(ID INT NOT NULL);
 ALTER TABLE TEST ADD CONSTRAINT PK PRIMARY KEY(ID);
 ALTER TABLE TEST ADD CONSTRAINT PK PRIMARY KEY(ID);
 

See Also:
Constant Field Values

URL_FORMAT_ERROR_2

public static final int URL_FORMAT_ERROR_2
The error with code 90046 is thrown when trying to open a connection to a database using an unsupported URL format. Please see the documentation on the supported URL format and examples. Example:
 jdbc:h2:;;
 

See Also:
Constant Field Values

DRIVER_VERSION_ERROR_2

public static final int DRIVER_VERSION_ERROR_2
The error with code 90047 is thrown when trying to connect to a TCP server with an incompatible client.

See Also:
Constant Field Values

FILE_VERSION_ERROR_1

public static final int FILE_VERSION_ERROR_1
The error with code 90048 is thrown when the file header of a database files (*.db) does not match the expected version, or if it is corrupted.

See Also:
Constant Field Values

FILE_ENCRYPTION_ERROR_1

public static final int FILE_ENCRYPTION_ERROR_1
The error with code 90049 is thrown when trying to open an encrypted database with the wrong file encryption password or algorithm.

See Also:
Constant Field Values

WRONG_PASSWORD_FORMAT

public static final int WRONG_PASSWORD_FORMAT
The error with code 90050 is thrown when trying to open an encrypted database, but not separating the file password from the user password. The file password is specified in the password field, before the user password. A single space needs to be added between the file password and the user password; the file password itself may not contain spaces. File passwords (as well as user passwords) are case sensitive. Example of wrong usage:
 String url = "jdbc:h2:˜/test;CIPHER=AES";
 String passwords = "filePasswordUserPassword";
 DriverManager.getConnection(url, "sa", pwds);
 
Correct:
 String url = "jdbc:h2:˜/test;CIPHER=AES";
 String passwords = "filePassword userPassword";
 DriverManager.getConnection(url, "sa", pwds);
 

See Also:
Constant Field Values

STATEMENT_WAS_CANCELED

public static final int STATEMENT_WAS_CANCELED
The error with code 90051 is thrown when a statement was canceled using Statement.cancel() or when the query timeout has been reached. Examples:
 stat.setQueryTimeout(1);
 stat.cancel();
 

See Also:
Constant Field Values

SUBQUERY_IS_NOT_SINGLE_COLUMN

public static final int SUBQUERY_IS_NOT_SINGLE_COLUMN
The error with code 90052 is thrown when a subquery that is used as a value contains more than one column. Example of wrong usage:
 CREATE TABLE TEST(ID INT);
 INSERT INTO TEST VALUES(1), (2);
 SELECT * FROM TEST WHERE ID IN (SELECT 1, 2 FROM DUAL);
 
Correct:
 CREATE TABLE TEST(ID INT);
 INSERT INTO TEST VALUES(1), (2);
 SELECT * FROM TEST WHERE ID IN (1, 2);
 

See Also:
Constant Field Values

SCALAR_SUBQUERY_CONTAINS_MORE_THAN_ONE_ROW

public static final int SCALAR_SUBQUERY_CONTAINS_MORE_THAN_ONE_ROW
The error with code 90053 is thrown when a subquery that is used as a value contains more than one row. Example:
 CREATE TABLE TEST(ID INT, NAME VARCHAR);
 INSERT INTO TEST VALUES(1, 'Hello'), (1, 'World');
 SELECT X, (SELECT NAME FROM TEST WHERE ID=X) FROM DUAL;
 

See Also:
Constant Field Values

INVALID_USE_OF_AGGREGATE_FUNCTION_1

public static final int INVALID_USE_OF_AGGREGATE_FUNCTION_1
The error with code 90054 is thrown when an aggregate function is used where it is not allowed. Example:
 CREATE TABLE TEST(ID INT);
 INSERT INTO TEST VALUES(1), (2);
 SELECT MAX(ID) FROM TEST WHERE ID = MAX(ID) GROUP BY ID;
 

See Also:
Constant Field Values

UNSUPPORTED_CIPHER

public static final int UNSUPPORTED_CIPHER
The error with code 90055 is thrown when trying to open a database with an unsupported cipher algorithm. Supported are AES and XTEA. Example:
 jdbc:h2:~/test;CIPHER=DES
 

See Also:
Constant Field Values

NO_DEFAULT_SET_1

public static final int NO_DEFAULT_SET_1
The error with code 90056 is thrown when updating or deleting from a table with a foreign key constraint that should set the default value, but there is no default value defined. Example:
 CREATE TABLE TEST(ID INT, PARENT INT);
 INSERT INTO TEST VALUES(1, 1), (2, 1);
 ALTER TABLE TEST ADD CONSTRAINT TEST_ID_PARENT
   FOREIGN KEY(PARENT) REFERENCES(ID) ON DELETE SET DEFAULT;
   DELETE FROM TEST WHERE ID=1;
 

See Also:
Constant Field Values

CONSTRAINT_NOT_FOUND_1

public static final int CONSTRAINT_NOT_FOUND_1
The error with code 90057 is thrown when trying to drop a constraint that does not exist. Example:
 CREATE TABLE TEST(ID INT);
 ALTER TABLE TEST DROP CONSTRAINT CID;
 

See Also:
Constant Field Values

COMMIT_ROLLBACK_NOT_ALLOWED

public static final int COMMIT_ROLLBACK_NOT_ALLOWED
The error with code 90058 is thrown when trying to call commit or rollback inside a trigger, or when trying to call a method inside a trigger that implicitly commits the current transaction, if an object is locked. This is not because it would release the lock too early.

See Also:
Constant Field Values

AMBIGUOUS_COLUMN_NAME_1

public static final int AMBIGUOUS_COLUMN_NAME_1
The error with code 90059 is thrown when a query contains a column that could belong to multiple tables. Example:
 CREATE TABLE PARENT(ID INT, NAME VARCHAR);
 CREATE TABLE CHILD(PID INT, NAME VARCHAR);
 SELECT ID, NAME FROM PARENT P, CHILD C WHERE P.ID = C.PID;
 

See Also:
Constant Field Values

UNSUPPORTED_LOCK_METHOD_1

public static final int UNSUPPORTED_LOCK_METHOD_1
The error with code 90060 is thrown when trying to use a file locking mechanism that is not supported. Currently only FILE (the default) and SOCKET are supported Example:
 jdbc:h2:~/test;FILE_LOCK=LDAP
 

See Also:
Constant Field Values

EXCEPTION_OPENING_PORT_2

public static final int EXCEPTION_OPENING_PORT_2
The error with code 90061 is thrown when trying to start a server if a server is already running on the same port. It could also be a firewall problem. To find out if another server is already running, run the following command on Windows:
 netstat -ano
 
The column PID is the process id as listed in the Task Manager. For Linux, use:
 netstat -npl
 

See Also:
Constant Field Values

FILE_CREATION_FAILED_1

public static final int FILE_CREATION_FAILED_1
The error with code 90062 is thrown when a directory or file could not be created. This can occur when trying to create a directory if a file with the same name already exists, or vice versa.

See Also:
Constant Field Values

SAVEPOINT_IS_INVALID_1

public static final int SAVEPOINT_IS_INVALID_1
The error with code 90063 is thrown when trying to rollback to a savepoint that is not defined. Example:
 ROLLBACK TO SAVEPOINT S_UNKNOWN;
 

See Also:
Constant Field Values

SAVEPOINT_IS_UNNAMED

public static final int SAVEPOINT_IS_UNNAMED
The error with code 90064 is thrown when Savepoint.getSavepointName() is called on an unnamed savepoint. Example:
 Savepoint sp = conn.setSavepoint();
 sp.getSavepointName();
 

See Also:
Constant Field Values

SAVEPOINT_IS_NAMED

public static final int SAVEPOINT_IS_NAMED
The error with code 90065 is thrown when Savepoint.getSavepointId() is called on a named savepoint. Example:
 Savepoint sp = conn.setSavepoint("Joe");
 sp.getSavepointId();
 

See Also:
Constant Field Values

DUPLICATE_PROPERTY_1

public static final int DUPLICATE_PROPERTY_1
The error with code 90066 is thrown when the same property appears twice in the database URL or in the connection properties. Example:
 jdbc:h2:~/test;LOG=0;LOG=1
 

See Also:
Constant Field Values

CONNECTION_BROKEN

public static final int CONNECTION_BROKEN
The error with code 90067 is thrown when the connection to the database is lost. A possible reason is that the connection has been closed due to a shutdown, or that the server is stopped.

See Also:
Constant Field Values

ORDER_BY_NOT_IN_RESULT

public static final int ORDER_BY_NOT_IN_RESULT
The error with code 90068 is thrown when the given expression that is used in the ORDER BY is not in the result list. This is required for distinct queries, otherwise the result would be ambiguous. Example of wrong usage:
 CREATE TABLE TEST(ID INT, NAME VARCHAR);
 INSERT INTO TEST VALUES(2, 'Hello'), (1, 'Hello');
 SELECT DISTINCT NAME FROM TEST ORDER BY ID;
 Order by expression ID must be in the result list in this case
 
Correct:
 SELECT DISTINCT ID, NAME FROM TEST ORDER BY ID;
 

See Also:
Constant Field Values

ROLE_ALREADY_EXISTS_1

public static final int ROLE_ALREADY_EXISTS_1
The error with code 90069 is thrown when trying to create a role if an object with this name already exists. Example:
 CREATE ROLE TEST_ROLE;
 CREATE ROLE TEST_ROLE;
 

See Also:
Constant Field Values

ROLE_NOT_FOUND_1

public static final int ROLE_NOT_FOUND_1
The error with code 90070 is thrown when trying to drop or grant a role that does not exists. Example:
 DROP ROLE TEST_ROLE_2;
 

See Also:
Constant Field Values

USER_OR_ROLE_NOT_FOUND_1

public static final int USER_OR_ROLE_NOT_FOUND_1
The error with code 90071 is thrown when trying to grant or revoke if no role or user with that name exists. Example:
 GRANT SELECT ON TEST TO UNKNOWN;
 

See Also:
Constant Field Values

ROLES_AND_RIGHT_CANNOT_BE_MIXED

public static final int ROLES_AND_RIGHT_CANNOT_BE_MIXED
The error with code 90072 is thrown when trying to grant or revoke if no role or user with that name exists. Example:
 GRANT SELECT, TEST_ROLE ON TEST TO SA;
 

See Also:
Constant Field Values

METHODS_MUST_HAVE_DIFFERENT_PARAMETER_COUNTS_2

public static final int METHODS_MUST_HAVE_DIFFERENT_PARAMETER_COUNTS_2
The error with code 90073 is thrown when trying to create an alias for a Java method, if two methods exists in this class that have this name and the same number of parameters. Example of wrong usage:
 CREATE ALIAS GET_LONG FOR
      "java.lang.Long.getLong";
 
Correct:
 CREATE ALIAS GET_LONG FOR
      "java.lang.Long.getLong(java.lang.String, java.lang.Long)";
 

See Also:
Constant Field Values

ROLE_ALREADY_GRANTED_1

public static final int ROLE_ALREADY_GRANTED_1
The error with code 90074 is thrown when trying to grant a role that has already been granted. Example:
 CREATE ROLE TEST_A;
 CREATE ROLE TEST_B;
 GRANT TEST_A TO TEST_B;
 GRANT TEST_B TO TEST_A;
 

See Also:
Constant Field Values

COLUMN_IS_PART_OF_INDEX_1

public static final int COLUMN_IS_PART_OF_INDEX_1
The error with code 90075 is thrown when trying to alter a table and allow null for a column that is part of a primary key or hash index. Example:
 CREATE TABLE TEST(ID INT PRIMARY KEY);
 ALTER TABLE TEST ALTER COLUMN ID NULL;
 

See Also:
Constant Field Values

FUNCTION_ALIAS_ALREADY_EXISTS_1

public static final int FUNCTION_ALIAS_ALREADY_EXISTS_1
The error with code 90076 is thrown when trying to create a function alias for a system function or for a function that is already defined. Example:
 CREATE ALIAS SQRT FOR "java.lang.Math.sqrt"
 

See Also:
Constant Field Values

FUNCTION_ALIAS_NOT_FOUND_1

public static final int FUNCTION_ALIAS_NOT_FOUND_1
The error with code 90077 is thrown when trying to drop a system function or a function alias that does not exist. Example:
 DROP ALIAS SQRT;
 

See Also:
Constant Field Values

SCHEMA_ALREADY_EXISTS_1

public static final int SCHEMA_ALREADY_EXISTS_1
The error with code 90078 is thrown when trying to create a schema if an object with this name already exists. Example:
 CREATE SCHEMA TEST_SCHEMA;
 CREATE SCHEMA TEST_SCHEMA;
 

See Also:
Constant Field Values

SCHEMA_NOT_FOUND_1

public static final int SCHEMA_NOT_FOUND_1
The error with code 90079 is thrown when trying to drop a schema that does not exist. Example:
 DROP SCHEMA UNKNOWN;
 

See Also:
Constant Field Values

SCHEMA_NAME_MUST_MATCH

public static final int SCHEMA_NAME_MUST_MATCH
The error with code 90080 is thrown when trying to rename a object to a different schema, or when trying to create a related object in another schema. For CREATE LINKED TABLE, it is thrown when multiple tables with that name exist in different schemas. Example:
 CREATE SCHEMA TEST_SCHEMA;
 CREATE TABLE TEST(ID INT);
 CREATE INDEX TEST_ID ON TEST(ID);
 ALTER INDEX TEST_ID RENAME TO TEST_SCHEMA.IDX_TEST_ID;
 

See Also:
Constant Field Values

COLUMN_CONTAINS_NULL_VALUES_1

public static final int COLUMN_CONTAINS_NULL_VALUES_1
The error with code 90081 is thrown when trying to alter a column to not allow NULL, if there is already data in the table where this column is NULL. Example:
 CREATE TABLE TEST(ID INT);
 INSERT INTO TEST VALUES(NULL);
 ALTER TABLE TEST ALTER COLUMN ID VARCHAR NOT NULL;
 

See Also:
Constant Field Values

SEQUENCE_BELONGS_TO_A_TABLE_1

public static final int SEQUENCE_BELONGS_TO_A_TABLE_1
The error with code 90082 is thrown when trying to drop a system generated sequence.

See Also:
Constant Field Values

COLUMN_MAY_BE_REFERENCED_1

public static final int COLUMN_MAY_BE_REFERENCED_1
The error with code 90083 is thrown when trying to drop a column that is part of a constraint. Example:
 CREATE TABLE TEST(ID INT, PID INT REFERENCES(ID));
 ALTER TABLE TEST DROP COLUMN PID;
 

See Also:
Constant Field Values

CANNOT_DROP_LAST_COLUMN

public static final int CANNOT_DROP_LAST_COLUMN
The error with code 90084 is thrown when trying to drop the last column of a table. Example:
 CREATE TABLE TEST(ID INT);
 ALTER TABLE TEST DROP COLUMN ID;
 

See Also:
Constant Field Values

INDEX_BELONGS_TO_CONSTRAINT_1

public static final int INDEX_BELONGS_TO_CONSTRAINT_1
The error with code 90085 is thrown when trying to manually drop an index that was generated by the system because of a unique constraint. Example of wrong usage:
 CREATE TABLE TEST(ID INT, CONSTRAINT UID UNIQUE(ID));
 DROP INDEX UID_INDEX_0;
 Index UID_INDEX_0 belongs to a constraint
 
Correct:
 ALTER TABLE TEST DROP CONSTRAINT UID;
 

See Also:
Constant Field Values

CLASS_NOT_FOUND_1

public static final int CLASS_NOT_FOUND_1
The error with code 90086 is thrown when a class can not be loaded because it is not in the classpath or because a related class is not in the classpath. Example:
 CREATE ALIAS TEST FOR "java.lang.invalid.Math.sqrt";
 

See Also:
Constant Field Values

METHOD_NOT_FOUND_1

public static final int METHOD_NOT_FOUND_1
The error with code 90087 is thrown when the specified method was not found in the class. Example:
 CREATE ALIAS TO_BINARY FOR "java.lang.Long.toBinaryString(long)";
 CALL TO_BINARY(10, 2);
 

See Also:
Constant Field Values

UNKNOWN_MODE_1

public static final int UNKNOWN_MODE_1
The error with code 90088 is thrown when trying to switch to an unknown mode. Example:
 SET MODE UNKNOWN;
 

See Also:
Constant Field Values

COLLATION_CHANGE_WITH_DATA_TABLE_1

public static final int COLLATION_CHANGE_WITH_DATA_TABLE_1
The error with code 90089 is thrown when trying to change the collation while there was already data in the database. The collation of the database must be set when the database is empty. Example of wrong usage:
 CREATE TABLE TEST(NAME VARCHAR PRIMARY KEY);
 INSERT INTO TEST VALUES('Hello', 'World');
 SET COLLATION DE;
 Collation cannot be changed because there is a data table: PUBLIC.TEST
 
Correct:
 SET COLLATION DE;
 CREATE TABLE TEST(NAME VARCHAR PRIMARY KEY);
 INSERT INTO TEST VALUES('Hello', 'World');
 

See Also:
Constant Field Values

SCHEMA_CAN_NOT_BE_DROPPED_1

public static final int SCHEMA_CAN_NOT_BE_DROPPED_1
The error with code 90090 is thrown when trying to drop a schema that may not be dropped (the schema PUBLIC and the schema INFORMATION_SCHEMA). Example:
 DROP SCHEMA PUBLIC;
 

See Also:
Constant Field Values

ROLE_CAN_NOT_BE_DROPPED_1

public static final int ROLE_CAN_NOT_BE_DROPPED_1
The error with code 90091 is thrown when trying to drop the role PUBLIC. Example:
 DROP ROLE PUBLIC;
 

See Also:
Constant Field Values

UNSUPPORTED_JAVA_VERSION

public static final int UNSUPPORTED_JAVA_VERSION
The error with code 90092 is thrown when the source code is not compiled for the Java platform used. At runtime, the existence of the class java.sql.Savepoint is checked. To run this database in JDK 1.3, it is first required to switch the source code to JDK 1.3 using ant switchSourceJdk13.

See Also:
Constant Field Values

CLUSTER_ERROR_DATABASE_RUNS_ALONE

public static final int CLUSTER_ERROR_DATABASE_RUNS_ALONE
The error with code 90093 is thrown when trying to connect to a clustered database that runs in standalone mode. This can happen if clustering is not enabled on the database, or if one of the clients disabled clustering because it can not see the other cluster node.

See Also:
Constant Field Values

CLUSTER_ERROR_DATABASE_RUNS_CLUSTERED_1

public static final int CLUSTER_ERROR_DATABASE_RUNS_CLUSTERED_1
The error with code 90094 is thrown when trying to connect to a clustered database that runs together with a different cluster node setting than what is used when trying to connect.

See Also:
Constant Field Values

STRING_FORMAT_ERROR_1

public static final int STRING_FORMAT_ERROR_1
The error with code 90095 is thrown when calling the method STRINGDECODE with an invalid escape sequence. Only Java style escape sequences and Java properties file escape sequences are supported. Example:
 CALL STRINGDECODE('\i');
 

See Also:
Constant Field Values

NOT_ENOUGH_RIGHTS_FOR_1

public static final int NOT_ENOUGH_RIGHTS_FOR_1
The error with code 90096 is thrown when trying to perform an operation with a non-admin user if the user does not have enough rights.

See Also:
Constant Field Values

DATABASE_IS_READ_ONLY

public static final int DATABASE_IS_READ_ONLY
The error with code 90097 is thrown when trying to delete or update a database if it is open in read-only mode. Example:
 jdbc:h2:~/test;ACCESS_MODE_DATA=R
 CREATE TABLE TEST(ID INT);
 

See Also:
Constant Field Values

SIMULATED_POWER_OFF

public static final int SIMULATED_POWER_OFF
The error with code 90098 is thrown when the self-destruction counter has reached zero. This counter is only used for recovery testing, and not set in normal operation.

See Also:
Constant Field Values

ERROR_SETTING_DATABASE_EVENT_LISTENER_2

public static final int ERROR_SETTING_DATABASE_EVENT_LISTENER_2
The error with code 90099 is thrown when an error occurred trying to initialize the database event listener. Example:
 jdbc:h2:˜/test;DATABASE_EVENT_LISTENER='java.lang.String'
 

See Also:
Constant Field Values

NO_DISK_SPACE_AVAILABLE

public static final int NO_DISK_SPACE_AVAILABLE
The error with code 90100 is thrown when there is no more space available on the device where the database files are stored.

See Also:
Constant Field Values

WRONG_XID_FORMAT_1

public static final int WRONG_XID_FORMAT_1
The error with code 90101 is thrown when the XA API detected unsupported transaction names. This can happen when mixing application generated transaction names and transaction names generated by this databases XAConnection API.

See Also:
Constant Field Values

UNSUPPORTED_COMPRESSION_OPTIONS_1

public static final int UNSUPPORTED_COMPRESSION_OPTIONS_1
The error with code 90102 is thrown when trying to use unsupported options for the given compression algorithm. Example of wrong usage:
 CALL COMPRESS(STRINGTOUTF8(SPACE(100)), 'DEFLATE l 10');
 
Correct:
 CALL COMPRESS(STRINGTOUTF8(SPACE(100)), 'DEFLATE l 9');
 

See Also:
Constant Field Values

UNSUPPORTED_COMPRESSION_ALGORITHM_1

public static final int UNSUPPORTED_COMPRESSION_ALGORITHM_1
The error with code 90103 is thrown when trying to use an unsupported compression algorithm. Example:
 CALL COMPRESS(STRINGTOUTF8(SPACE(100)), 'BZIP');
 

See Also:
Constant Field Values

COMPRESSION_ERROR

public static final int COMPRESSION_ERROR
The error with code 90104 is thrown when the data can not be de-compressed. Example:
 CALL EXPAND(X'00FF');
 

See Also:
Constant Field Values

EXCEPTION_IN_FUNCTION

public static final int EXCEPTION_IN_FUNCTION
The error with code 90105 is thrown when an exception occurred in a user-defined method. Example:
 CREATE ALIAS SYS_PROP FOR "java.lang.System.getProperty";
 CALL SYS_PROP(NULL);
 

See Also:
Constant Field Values

CANNOT_TRUNCATE_1

public static final int CANNOT_TRUNCATE_1
The error with code 90106 is thrown when trying to truncate a table that can not be truncated. Tables with referential integrity constraints can not be truncated. Also, system tables and view can not be truncated. Example:
 TRUNCATE TABLE INFORMATION_SCHEMA.SETTINGS;
 

See Also:
Constant Field Values

CANNOT_DROP_2

public static final int CANNOT_DROP_2
The error with code 90107 is thrown when trying to drop an object because another object would become invalid. Example:
 CREATE TABLE COUNT(X INT);
 CREATE TABLE ITEMS(ID INT DEFAULT SELECT MAX(X)+1 FROM COUNT);
 DROP TABLE COUNT;
 

See Also:
Constant Field Values

OUT_OF_MEMORY

public static final int OUT_OF_MEMORY
The error with code 90108 is thrown when not enough heap memory was available. A possible solutions is to increase the memory size using java -Xmx128m .... Another solution is to reduce the cache size.

See Also:
Constant Field Values

VIEW_IS_INVALID_2

public static final int VIEW_IS_INVALID_2
The error with code 90109 is thrown when trying to run a query against an invalid view. Example:
 CREATE FORCE VIEW TEST_VIEW AS SELECT * FROM TEST;
 SELECT * FROM TEST_VIEW;
 

See Also:
Constant Field Values

OVERFLOW_FOR_TYPE_1

public static final int OVERFLOW_FOR_TYPE_1
The error with code 90110 is thrown when the result of the calculation does not fit in the given data type. Example:
 CALL -CAST(-128 AS TINYINT);
 

See Also:
Constant Field Values

ERROR_ACCESSING_LINKED_TABLE_2

public static final int ERROR_ACCESSING_LINKED_TABLE_2
The error with code 90111 is thrown when an exception occurred while accessing a linked table.

See Also:
Constant Field Values

ROW_NOT_FOUND_WHEN_DELETING_1

public static final int ROW_NOT_FOUND_WHEN_DELETING_1
The error with code 90112 is thrown when a row was deleted twice while locking was disabled. This is an intern exception that should never be thrown to the application, because such deleted should be detected and the resulting exception ignored inside the database engine.
 Row not found when trying to delete from index UID_INDEX_0
 

See Also:
Constant Field Values

UNSUPPORTED_SETTING_1

public static final int UNSUPPORTED_SETTING_1
The error with code 90113 is thrown when the database URL contains unsupported settings. Example:
 jdbc:h2:~/test;UNKNOWN=TRUE
 

See Also:
Constant Field Values

CONSTANT_ALREADY_EXISTS_1

public static final int CONSTANT_ALREADY_EXISTS_1
The error with code 90114 is thrown when trying to create a constant if a constant with this name already exists. Example:
 CREATE CONSTANT TEST VALUE 1;
 CREATE CONSTANT TEST VALUE 1;
 

See Also:
Constant Field Values

CONSTANT_NOT_FOUND_1

public static final int CONSTANT_NOT_FOUND_1
The error with code 90115 is thrown when trying to drop a constant that does not exists. Example:
 DROP CONSTANT UNKNOWN;
 

See Also:
Constant Field Values

LITERALS_ARE_NOT_ALLOWED

public static final int LITERALS_ARE_NOT_ALLOWED
The error with code 90116 is thrown when trying use a literal in a SQL statement if literals are disabled. If literals are disabled, use PreparedStatement and parameters instead of literals in the SQL statement. Example:
 SET ALLOW_LITERALS NONE;
 CALL 1+1;
 

See Also:
Constant Field Values

REMOTE_CONNECTION_NOT_ALLOWED

public static final int REMOTE_CONNECTION_NOT_ALLOWED
The error with code 90117 is thrown when trying to connect to a TCP server from another machine, if remote connections are not allowed. To allow remote connections, start the TCP server using the option -tcpAllowOthers as in:
 java org.h2.tools.Server -tcp -tcpAllowOthers
 
Or, when starting the server from an application, use:
 Server server = Server.createTcpServer("-tcpAllowOthers");
 server.start();
 

See Also:
Constant Field Values

CANNOT_DROP_TABLE_1

public static final int CANNOT_DROP_TABLE_1
The error with code 90118 is thrown when trying to drop a table can not be dropped. Example:
 DROP TABLE INFORMATION_SCHEMA.SETTINGS;
 

See Also:
Constant Field Values

USER_DATA_TYPE_ALREADY_EXISTS_1

public static final int USER_DATA_TYPE_ALREADY_EXISTS_1
The error with code 90119 is thrown when trying to create a domain if an object with this name already exists, or when trying to overload a built-in data type. Example:
 CREATE DOMAIN INTEGER AS VARCHAR;
 CREATE DOMAIN EMAIL AS VARCHAR CHECK LOCATE('@', VALUE) > 0;
 CREATE DOMAIN EMAIL AS VARCHAR CHECK LOCATE('@', VALUE) > 0;
 

See Also:
Constant Field Values

USER_DATA_TYPE_NOT_FOUND_1

public static final int USER_DATA_TYPE_NOT_FOUND_1
The error with code 90120 is thrown when trying to drop a domain that doesn't exists. Example:
 DROP DOMAIN UNKNOWN;
 

See Also:
Constant Field Values

DATABASE_CALLED_AT_SHUTDOWN

public static final int DATABASE_CALLED_AT_SHUTDOWN
The error with code 90121 is thrown when a database operation is started while the virtual machine exits (for example in a shutdown hook), or when the session is closed.

See Also:
Constant Field Values

OPERATION_NOT_SUPPORTED_WITH_VIEWS_2

public static final int OPERATION_NOT_SUPPORTED_WITH_VIEWS_2
The error with code 90122 is thrown when trying to altering, adding or dropping columns of a table that has views. Example:
 CREATE TABLE TEST(ID INT);
 CREATE VIEW TEST_VIEW AS SELECT * FROM TEST;
 ALTER TABLE TEST ADD COLUMN NAME VARCHAR;
 

See Also:
Constant Field Values

CANNOT_MIX_INDEXED_AND_UNINDEXED_PARAMS

public static final int CANNOT_MIX_INDEXED_AND_UNINDEXED_PARAMS
The error with code 90123 is thrown when trying mix regular parameters and indexed parameters in the same statement. Example:
 SELECT ?, ?1 FROM DUAL;
 

See Also:
Constant Field Values

FILE_NOT_FOUND_1

public static final int FILE_NOT_FOUND_1
The error with code 90124 is thrown when trying to access a file that doesn't exist. This can occur when trying to read a lob if the lob file has been deleted by another application.

See Also:
Constant Field Values

INVALID_CLASS_2

public static final int INVALID_CLASS_2
The error with code 90125 is thrown when PreparedStatement.setBigDecimal is called with object that extends the class BigDecimal, and the system property h2.allowBigDecimalExtensions is not set. Using extensions of BigDecimal is dangerous because the database relies on the behavior of BigDecimal. Example of wrong usage:
 BigDecimal bd = new MyDecimal("$10.3");
 prep.setBigDecimal(1, bd);
 Invalid class, expected java.math.BigDecimal but got MyDecimal
 
Correct:
 BigDecimal bd = new BigDecimal("10.3");
 prep.setBigDecimal(1, bd);
 

See Also:
Constant Field Values

DATABASE_IS_NOT_PERSISTENT

public static final int DATABASE_IS_NOT_PERSISTENT
The error with code 90126 is thrown when trying to call the BACKUP statement for an in-memory database. Example:
 jdbc:h2:mem:
 BACKUP TO 'test.zip';
 

See Also:
Constant Field Values

RESULT_SET_NOT_UPDATABLE

public static final int RESULT_SET_NOT_UPDATABLE
The error with code 90127 is thrown when trying to update or delete a row in a result set if the result set is not updatable. Result sets are only updatable if the statement was created with updatable concurrency, and if the result set contains all columns of the primary key or of a unique index of a table.

See Also:
Constant Field Values

RESULT_SET_NOT_SCROLLABLE

public static final int RESULT_SET_NOT_SCROLLABLE
The error with code 90128 is thrown when trying to call a method of the ResultSet that is only supported for scrollable result sets, and the result set is not scrollable. Example:
 rs.first();
 

See Also:
Constant Field Values

TRANSACTION_NOT_FOUND_1

public static final int TRANSACTION_NOT_FOUND_1
The error with code 90129 is thrown when trying to commit a transaction that doesn't exist. Example:
 PREPARE COMMIT ABC;
 COMMIT TRANSACTION TEST;
 

See Also:
Constant Field Values

METHOD_NOT_ALLOWED_FOR_PREPARED_STATEMENT

public static final int METHOD_NOT_ALLOWED_FOR_PREPARED_STATEMENT
The error with code 90130 is thrown when an execute method of PreparedStatement was called with a SQL statement. This is not allowed according to the JDBC specification. Instead, use an execute method of Statement. Example of wrong usage:
 PreparedStatement prep = conn.prepareStatement("SELECT * FROM TEST");
 prep.execute("DELETE FROM TEST");
 
Correct:
 Statement stat = conn.createStatement();
 stat.execute("DELETE FROM TEST");
 

See Also:
Constant Field Values

CONCURRENT_UPDATE_1

public static final int CONCURRENT_UPDATE_1
The error with code 90131 is thrown when using multi version concurrency control, and trying to update the same row from within two connections at the same time. Example:
 jdbc:h2:~/test;MVCC=TRUE
 Session 1:
 CREATE TABLE TEST(ID INT);
 INSERT INTO TEST VALUES(1);
 SET AUTOCOMMIT FALSE;
 UPDATE TEST SET ID = 2;
 Session 2:
 SET AUTOCOMMIT FALSE;
 UPDATE TEST SET ID = 3;
 

See Also:
Constant Field Values

AGGREGATE_NOT_FOUND_1

public static final int AGGREGATE_NOT_FOUND_1
The error with code 90132 is thrown when trying to drop a user-defined aggregate function that doesn't exist. Example:
 DROP AGGREGATE UNKNOWN;
 

See Also:
Constant Field Values

CANNOT_CHANGE_SETTING_WHEN_OPEN_1

public static final int CANNOT_CHANGE_SETTING_WHEN_OPEN_1
The error with code 90133 is thrown when trying to change a specific database property while the database is already open. The MVCC property needs to be set in the first connection (in the connection opening the database) and can not be changed later on.

See Also:
Constant Field Values

ACCESS_DENIED_TO_CLASS_1

public static final int ACCESS_DENIED_TO_CLASS_1
The error with code 90134 is thrown when trying to load a Java class that is not part of the allowed classes. By default, all classes are allowed, but this can be changed using the system property h2.allowedClasses.

See Also:
Constant Field Values

DATABASE_IS_IN_EXCLUSIVE_MODE

public static final int DATABASE_IS_IN_EXCLUSIVE_MODE
The error with code 90135 is thrown when trying to open a connection to a database that is currently open in exclusive mode. The exclusive mode is set using:
 SET EXCLUSIVE TRUE;
 

See Also:
Constant Field Values

UNSUPPORTED_OUTER_JOIN_CONDITION_1

public static final int UNSUPPORTED_OUTER_JOIN_CONDITION_1
The error with code 90136 is thrown when executing a query that used an unsupported outer join condition. Example:
 SELECT * FROM DUAL A LEFT JOIN DUAL B ON B.X=(SELECT MAX(X) FROM DUAL);
 

See Also:
Constant Field Values

CAN_ONLY_ASSIGN_TO_VARIABLE_1

public static final int CAN_ONLY_ASSIGN_TO_VARIABLE_1
The error with code 90137 is thrown when trying to assign a value to something that is not a variable.
 SELECT AMOUNT, SET(@V, IFNULL(@V, 0)+AMOUNT) FROM TEST;
 

See Also:
Constant Field Values

INVALID_DATABASE_NAME_1

public static final int INVALID_DATABASE_NAME_1
The error with code 90138 is thrown when trying to open a persistent database using an incorrect database name. The name of a persistent database contains the path and file name prefix where the data is stored. The file name part of a database name must be at least two characters. Example of wrong usage:
 DriverManager.getConnection("jdbc:h2:~/t");
 DriverManager.getConnection("jdbc:h2:~/test/");
 
Correct:
 DriverManager.getConnection("jdbc:h2:~/te");
 DriverManager.getConnection("jdbc:h2:~/test/te");
 

See Also:
Constant Field Values

PUBLIC_STATIC_JAVA_METHOD_NOT_FOUND_1

public static final int PUBLIC_STATIC_JAVA_METHOD_NOT_FOUND_1
The error with code 90139 is thrown when the specified public static Java method was not found in the class. Example:
 CREATE ALIAS TEST FOR "java.lang.Math.test";
 

See Also:
Constant Field Values

RESULT_SET_READONLY

public static final int RESULT_SET_READONLY
The error with code 90140 is thrown when trying to update or delete a row in a result set if the statement was not created with updatable concurrency. Result sets are only updatable if the statement was created with updatable concurrency, and if the result set contains all columns of the primary key or of a unique index of a table.

See Also:
Constant Field Values
Method Detail

isCommon

public static boolean isCommon(int errorCode)
INTERNAL


getState

public static java.lang.String getState(int errorCode)
INTERNAL