blob: 9f967aafff9ee3ae4e494bfa6268e92d11600380 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to you under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.calcite.avatica;
import java.io.BufferedWriter;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.nio.charset.StandardCharsets;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
/**
* SQL error codes.
*
* <p>Based upon Table 33 &mdash; SQLSTATE class and subclass values in
* SQL:2014 section 24.1, which is as follows.
*
* <table border=1>
* <caption>Table 33 &mdash; SQLSTATE class and subclass values</caption>
* <tr>
* <th>Category</th>
* <th>Condition</th>
* <th>Class</th>
* <th>Subcondition</th>
* <th>Subclass</th>
* </tr>
* <tr>
* <td>X</td>
* <td>ambiguous cursor name</td>
* <td>3C</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>attempt to assign to non-updatable column</td>
* <td>0U</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>attempt to assign to ordering column</td>
* <td>0V</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>cli specific condition</td>
* <td>HY</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>cardinality violation</td>
* <td>21</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>connection exception</td>
* <td>08</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>connection does not exist</td>
* <td>003</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>connection failure</td>
* <td>006</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>connection name in use</td>
* <td>002</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>SQL-client unable to establish SQL-connection</td>
* <td>001</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>SQL-server rejected establishment of SQL-connection</td>
* <td>004</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>transaction resolution unknown</td>
* <td>007</td>
* </tr>
* <tr>
* <td>X</td>
* <td>cursor sensitivity exception</td>
* <td>36</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>request failed</td>
* <td>002</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>request rejected</td>
* <td>001</td>
* </tr>
* <tr>
* <td>X</td>
* <td>data exception</td>
* <td>22</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>array data, right truncation</td>
* <td>02F</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>array element error</td>
* <td>02E</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>attempt to replace a zero-length string</td>
* <td>01U</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>character not in repertoire</td>
* <td>021</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>datetime field overflow</td>
* <td>008</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>division by zero</td>
* <td>012</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>error in assignment</td>
* <td>005</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>escape character conflict</td>
* <td>00B</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>indicator overflow</td>
* <td>022</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>interval field overflow</td>
* <td>015</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>interval value out of range</td>
* <td>00P</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid argument for natural logarithm</td>
* <td>01E</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid argument for NTILE function</td>
* <td>014</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid argument for NTH_VALUE function</td>
* <td>016</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid argument for power function</td>
* <td>01F</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid argument for row pattern navigation operation</td>
* <td>02J</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid argument for width bucket function</td>
* <td>01G</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid character value for cast</td>
* <td>018</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid datetime format</td>
* <td>007</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid escape character</td>
* <td>019</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid escape octet</td>
* <td>00D</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid escape sequence</td>
* <td>025</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid indicator parameter value</td>
* <td>010</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid interval format</td>
* <td>006</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid parameter value</td>
* <td>023</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid period value</td>
* <td>020</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid preceding or following size in window function</td>
* <td>013</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid regular expression</td>
* <td>01B</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid repeat argument in a sample clause</td>
* <td>02G</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid row count in fetch first clause</td>
* <td>01W</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid row count in result offset clause</td>
* <td>01X</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid row version</td>
* <td>01H</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid sample size</td>
* <td>02H</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid time zone displacement value</td>
* <td>009</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid use of escape character</td>
* <td>00C</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid XQuery option flag</td>
* <td>01T</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid XQuery regular expression</td>
* <td>01S</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid XQuery replacement string</td>
* <td>01V</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>most specific type mismatch</td>
* <td>00G</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>multiset value overflow</td>
* <td>00Q</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>noncharacter in UCS string</td>
* <td>029</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>null value substituted for mutator subject parameter</td>
* <td>02D</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>null row not permitted in table</td>
* <td>01C</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>null value in array target</td>
* <td>00E</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>null value, no indicator parameter</td>
* <td>002</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>null value not allowed</td>
* <td>004</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>numeric value out of range</td>
* <td>003</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>sequence generator limit exceeded</td>
* <td>00H</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>skip to non-existent row</td>
* <td>02K</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>skip to first row of match</td>
* <td>02L</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>string data, length mismatch</td>
* <td>026</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>string data, right truncation</td>
* <td>001</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>substring error</td>
* <td>011</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>trim error</td>
* <td>027</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>unterminated C string</td>
* <td>024</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>zero-length character string</td>
* <td>00F</td>
* </tr>
* <tr>
* <td>X</td>
* <td>dependent privilege descriptors still exist</td>
* <td>2B</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>diagnostics exception</td>
* <td>0Z</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>maximum number of stacked diagnostics areas exceeded</td>
* <td>001</td>
* </tr>
* <tr>
* <td>X</td>
* <td>dynamic SQL error</td>
* <td>07</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>cursor specification cannot be executed</td>
* <td>003</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>data type transform function violation</td>
* <td>00B</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid DATA target</td>
* <td>00D</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid DATETIME_INTERVAL_CODE</td>
* <td>00F</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid descriptor count</td>
* <td>008</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid descriptor index</td>
* <td>009</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid LEVEL value</td>
* <td>00E</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>prepared statement not a cursor specification</td>
* <td>005</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>restricted data type attribute violation</td>
* <td>006</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>undefined DATA value</td>
* <td>00C</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>using clause does not match dynamic parameter specifications</td>
* <td>001</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>using clause does not match target specifications</td>
* <td>002</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>using clause required for dynamic parameters</td>
* <td>004</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>using clause required for result fields</td>
* <td>007</td>
* </tr>
* <tr>
* <td>X</td>
* <td>external routine exception</td>
* <td>38</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>containing SQL not permitted</td>
* <td>001</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>modifying SQL-data not permitted</td>
* <td>002</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>prohibited SQL-statement attempted</td>
* <td>003</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>reading SQL-data not permitted</td>
* <td>004</td>
* </tr>
* <tr>
* <td>X</td>
* <td>external routine invocation exception</td>
* <td>39</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>null value not allowed</td>
* <td>004</td>
* </tr>
* <tr>
* <td>X</td>
* <td>feature not supported</td>
* <td>0A</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>multiple server transactions</td>
* <td>001</td>
* </tr>
* <tr>
* <td>X</td>
* <td>integrity constraint violation</td>
* <td>23</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>restrict violation</td>
* <td>001</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid authorization specification</td>
* <td>28</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid catalog name</td>
* <td>3D</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid character set name</td>
* <td>2C</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>cannot drop SQL-session default character set</td>
* <td>001</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid condition number</td>
* <td>35</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid connection name</td>
* <td>2E</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid cursor name</td>
* <td>34</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid cursor state</td>
* <td>24</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid grantor</td>
* <td>0L</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid role specification</td>
* <td>0P</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid schema name</td>
* <td>3F</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid schema name list specification</td>
* <td>0E</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid collation name</td>
* <td>2H</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid SQL descriptor name</td>
* <td>33</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid SQL-invoked procedure reference</td>
* <td>0M</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid SQL statement name</td>
* <td>26</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid SQL statement identifier</td>
* <td>30</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid target type specification</td>
* <td>0D</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid transaction state</td>
* <td>25</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>active SQL-transaction</td>
* <td>001</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>branch transaction already active</td>
* <td>002</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>held cursor requires same isolation level</td>
* <td>008</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>inappropriate access mode for branch transaction</td>
* <td>003</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>inappropriate isolation level for branch transaction</td>
* <td>004</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>no active SQL-transaction for branch transaction</td>
* <td>005</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>read-only SQL-transaction</td>
* <td>006</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>schema and data statement mixing not supported</td>
* <td>007</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid transaction termination</td>
* <td>2D</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>invalid transform group name specification</td>
* <td>0S</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>locator exception</td>
* <td>0F</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid specification</td>
* <td>001</td>
* </tr>
* <tr>
* <td>N</td>
* <td>no data</td>
* <td>02</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>no additional result sets returned</td>
* <td>001</td>
* </tr>
* <tr>
* <td>X</td>
* <td>prohibited statement encountered during trigger execution</td>
* <td>0W</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>modify table modified by data change delta table</td>
* <td>001</td>
* </tr>
* <tr>
* <td>X</td>
* <td>Remote Database Access</td>
* <td>HZ</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>savepoint exception</td>
* <td>3B</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid specification</td>
* <td>001</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>too many</td>
* <td>002</td>
* </tr>
* <tr>
* <td>X</td>
* <td>SQL routine exception</td>
* <td>2F</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>function executed no return statement</td>
* <td>005</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>modifying SQL-data not permitted</td>
* <td>002</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>prohibited SQL-statement attempted</td>
* <td>003</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>reading SQL-data not permitted</td>
* <td>004</td>
* </tr>
* <tr>
* <td>S</td>
* <td>successful completion</td>
* <td>00</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>syntax error or access rule violation</td>
* <td>42</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>syntax error or access rule violation in direct statement</td>
* <td>2A</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>syntax error or access rule violation in dynamic statement</td>
* <td>37</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>target table disagrees with cursor specification</td>
* <td>0T</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>transaction rollback</td>
* <td>40</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>integrity constraint violation</td>
* <td>002</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>serialization failure</td>
* <td>001</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>statement completion unknown</td>
* <td>003</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>triggered action exception</td>
* <td>004</td>
* </tr>
* <tr>
* <td>X</td>
* <td>triggered action exception</td>
* <td>09</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>X</td>
* <td>triggered data change violation</td>
* <td>27</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>modify table modified by data change delta table</td>
* <td>001</td>
* </tr>
* <tr>
* <td>W</td>
* <td>warning</td>
* <td>01</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>additional result sets returned</td>
* <td>00D</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>array data, right truncation</td>
* <td>02F</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>attempt to return too many result sets</td>
* <td>00E</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>cursor operation conflict</td>
* <td>001</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>default value too long for information schema</td>
* <td>00B</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>disconnect error</td>
* <td>002</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>insufficient item descriptor areas</td>
* <td>005</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>invalid number of conditions</td>
* <td>012</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>null value eliminated in set function</td>
* <td>003</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>privilege not granted</td>
* <td>007</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>privilege not revoked</td>
* <td>006</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>query expression too long for information schema</td>
* <td>00A</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>result sets returned</td>
* <td>00C</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>search condition too long for information schema</td>
* <td>009</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>statement too long for information schema</td>
* <td>00F</td>
* </tr>
* <tr>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>&nbsp;</td>
* <td>string data, right truncation</td>
* <td>004</td>
* </tr>
* <tr>
* <td>X</td>
* <td>with check option violation</td>
* <td>44</td>
* <td>(no subclass)</td>
* <td>000</td>
* </tr>
* </table>
*/
public enum SqlState {
/** 3C000: ambiguous cursor name */
AMBIGUOUS_CURSOR_NAME_NO_SUBCLASS(Category.X, "ambiguous cursor name", "3C", null, null),
/** 0U000: attempt to assign to non-updatable column */
ATTEMPT_TO_ASSIGN_TO_NON_UPDATABLE_COLUMN_NO_SUBCLASS(Category.X,
"attempt to assign to non-updatable column", "0U", null, null),
/** 0V000: attempt to assign to ordering column */
ATTEMPT_TO_ASSIGN_TO_ORDERING_COLUMN_NO_SUBCLASS(Category.X,
"attempt to assign to ordering column", "0V", null, null),
/** HY000: cli specific condition */
CLI_SPECIFIC_CONDITION_NO_SUBCLASS(Category.X, "cli specific condition", "HY", null, null),
/** 21000: cardinality violation */
CARDINALITY_VIOLATION_NO_SUBCLASS(Category.X, "cardinality violation", "21", null, null),
/** 08000: connection exception */
CONNECTION_EXCEPTION_NO_SUBCLASS(Category.X, "connection exception", "08", null, null),
/** 08003: connection exception: connection does not exist */
CONNECTION_EXCEPTION_CONNECTION_DOES_NOT_EXIST(Category.X, "connection exception", "08",
"connection does not exist", "003"),
/** 08006: connection exception: connection failure */
CONNECTION_EXCEPTION_CONNECTION_FAILURE(Category.X, "connection exception", "08",
"connection failure", "006"),
/** 08002: connection exception: connection name in use */
CONNECTION_EXCEPTION_CONNECTION_NAME_IN_USE(Category.X, "connection exception", "08",
"connection name in use", "002"),
/** 08001: connection exception: SQL-client unable to establish SQL-connection */
CONNECTION_EXCEPTION_SQLCLIENT_UNABLE_TO_ESTABLISH_SQLCONNECTION(Category.X,
"connection exception", "08", "SQL-client unable to establish SQL-connection", "001"),
/** 08004: connection exception: SQL-server rejected establishment of SQL-connection */
CONNECTION_EXCEPTION_SQLSERVER_REJECTED_ESTABLISHMENT_OF_SQLCONNECTION(Category.X,
"connection exception", "08", "SQL-server rejected establishment of SQL-connection", "004"),
/** 08007: connection exception: transaction resolution unknown */
CONNECTION_EXCEPTION_TRANSACTION_RESOLUTION_UNKNOWN(Category.X, "connection exception", "08",
"transaction resolution unknown", "007"),
/** 36000: cursor sensitivity exception */
CURSOR_SENSITIVITY_EXCEPTION_NO_SUBCLASS(Category.X, "cursor sensitivity exception", "36", null,
null),
/** 36002: cursor sensitivity exception: request failed */
CURSOR_SENSITIVITY_EXCEPTION_REQUEST_FAILED(Category.X, "cursor sensitivity exception", "36",
"request failed", "002"),
/** 36001: cursor sensitivity exception: request rejected */
CURSOR_SENSITIVITY_EXCEPTION_REQUEST_REJECTED(Category.X, "cursor sensitivity exception", "36",
"request rejected", "001"),
/** 22000: data exception */
DATA_EXCEPTION_NO_SUBCLASS(Category.X, "data exception", "22", null, null),
/** 2202F: data exception: array data, right truncation */
DATA_EXCEPTION_ARRAY_DATA_RIGHT_TRUNCATION(Category.X, "data exception", "22",
"array data, right truncation", "02F"),
/** 2202E: data exception: array element error */
DATA_EXCEPTION_ARRAY_ELEMENT_ERROR(Category.X, "data exception", "22", "array element error",
"02E"),
/** 2201U: data exception: attempt to replace a zero-length string */
DATA_EXCEPTION_ATTEMPT_TO_REPLACE_A_ZERO_LENGTH_STRING(Category.X, "data exception", "22",
"attempt to replace a zero-length string", "01U"),
/** 22021: data exception: character not in repertoire */
DATA_EXCEPTION_CHARACTER_NOT_IN_REPERTOIRE(Category.X, "data exception", "22",
"character not in repertoire", "021"),
/** 22008: data exception: datetime field overflow */
DATA_EXCEPTION_DATETIME_FIELD_OVERFLOW(Category.X, "data exception", "22",
"datetime field overflow", "008"),
/** 22012: data exception: division by zero */
DATA_EXCEPTION_DIVISION_BY_ZERO(Category.X, "data exception", "22", "division by zero", "012"),
/** 22005: data exception: error in assignment */
DATA_EXCEPTION_ERROR_IN_ASSIGNMENT(Category.X, "data exception", "22", "error in assignment",
"005"),
/** 2200B: data exception: escape character conflict */
DATA_EXCEPTION_ESCAPE_CHARACTER_CONFLICT(Category.X, "data exception", "22",
"escape character conflict", "00B"),
/** 22022: data exception: indicator overflow */
DATA_EXCEPTION_INDICATOR_OVERFLOW(Category.X, "data exception", "22", "indicator overflow",
"022"),
/** 22015: data exception: interval field overflow */
DATA_EXCEPTION_INTERVAL_FIELD_OVERFLOW(Category.X, "data exception", "22",
"interval field overflow", "015"),
/** 2200P: data exception: interval value out of range */
DATA_EXCEPTION_INTERVAL_VALUE_OUT_OF_RANGE(Category.X, "data exception", "22",
"interval value out of range", "00P"),
/** 2201E: data exception: invalid argument for natural logarithm */
DATA_EXCEPTION_INVALID_ARGUMENT_FOR_NATURAL_LOGARITHM(Category.X, "data exception", "22",
"invalid argument for natural logarithm", "01E"),
/** 22014: data exception: invalid argument for NTILE function */
DATA_EXCEPTION_INVALID_ARGUMENT_FOR_NTILE_FUNCTION(Category.X, "data exception", "22",
"invalid argument for NTILE function", "014"),
/** 22016: data exception: invalid argument for NTH_VALUE function */
DATA_EXCEPTION_INVALID_ARGUMENT_FOR_NTH_VALUE_FUNCTION(Category.X, "data exception", "22",
"invalid argument for NTH_VALUE function", "016"),
/** 2201F: data exception: invalid argument for power function */
DATA_EXCEPTION_INVALID_ARGUMENT_FOR_POWER_FUNCTION(Category.X, "data exception", "22",
"invalid argument for power function", "01F"),
/** 2202J: data exception: invalid argument for row pattern navigation operation */
DATA_EXCEPTION_INVALID_ARGUMENT_FOR_ROW_PATTERN_NAVIGATION_OPERATION(Category.X, "data exception",
"22", "invalid argument for row pattern navigation operation", "02J"),
/** 2201G: data exception: invalid argument for width bucket function */
DATA_EXCEPTION_INVALID_ARGUMENT_FOR_WIDTH_BUCKET_FUNCTION(Category.X, "data exception", "22",
"invalid argument for width bucket function", "01G"),
/** 22018: data exception: invalid character value for cast */
DATA_EXCEPTION_INVALID_CHARACTER_VALUE_FOR_CAST(Category.X, "data exception", "22",
"invalid character value for cast", "018"),
/** 22007: data exception: invalid datetime format */
DATA_EXCEPTION_INVALID_DATETIME_FORMAT(Category.X, "data exception", "22",
"invalid datetime format", "007"),
/** 22019: data exception: invalid escape character */
DATA_EXCEPTION_INVALID_ESCAPE_CHARACTER(Category.X, "data exception", "22",
"invalid escape character", "019"),
/** 2200D: data exception: invalid escape octet */
DATA_EXCEPTION_INVALID_ESCAPE_OCTET(Category.X, "data exception", "22", "invalid escape octet",
"00D"),
/** 22025: data exception: invalid escape sequence */
DATA_EXCEPTION_INVALID_ESCAPE_SEQUENCE(Category.X, "data exception", "22",
"invalid escape sequence", "025"),
/** 22010: data exception: invalid indicator parameter value */
DATA_EXCEPTION_INVALID_INDICATOR_PARAMETER_VALUE(Category.X, "data exception", "22",
"invalid indicator parameter value", "010"),
/** 22006: data exception: invalid interval format */
DATA_EXCEPTION_INVALID_INTERVAL_FORMAT(Category.X, "data exception", "22",
"invalid interval format", "006"),
/** 22023: data exception: invalid parameter value */
DATA_EXCEPTION_INVALID_PARAMETER_VALUE(Category.X, "data exception", "22",
"invalid parameter value", "023"),
/** 22020: data exception: invalid period value */
DATA_EXCEPTION_INVALID_PERIOD_VALUE(Category.X, "data exception", "22", "invalid period value",
"020"),
/** 22013: data exception: invalid preceding or following size in window function */
DATA_EXCEPTION_INVALID_PRECEDING_OR_FOLLOWING_SIZE_IN_WINDOW_FUNCTION(Category.X,
"data exception", "22", "invalid preceding or following size in window function", "013"),
/** 2201B: data exception: invalid regular expression */
DATA_EXCEPTION_INVALID_REGULAR_EXPRESSION(Category.X, "data exception", "22",
"invalid regular expression", "01B"),
/** 2202G: data exception: invalid repeat argument in a sample clause */
DATA_EXCEPTION_INVALID_REPEAT_ARGUMENT_IN_A_SAMPLE_CLAUSE(Category.X, "data exception", "22",
"invalid repeat argument in a sample clause", "02G"),
/** 2201W: data exception: invalid row count in fetch first clause */
DATA_EXCEPTION_INVALID_ROW_COUNT_IN_FETCH_FIRST_CLAUSE(Category.X, "data exception", "22",
"invalid row count in fetch first clause", "01W"),
/** 2201X: data exception: invalid row count in result offset clause */
DATA_EXCEPTION_INVALID_ROW_COUNT_IN_RESULT_OFFSET_CLAUSE(Category.X, "data exception", "22",
"invalid row count in result offset clause", "01X"),
/** 2201H: data exception: invalid row version */
DATA_EXCEPTION_INVALID_ROW_VERSION(Category.X, "data exception", "22", "invalid row version",
"01H"),
/** 2202H: data exception: invalid sample size */
DATA_EXCEPTION_INVALID_SAMPLE_SIZE(Category.X, "data exception", "22", "invalid sample size",
"02H"),
/** 22009: data exception: invalid time zone displacement value */
DATA_EXCEPTION_INVALID_TIME_ZONE_DISPLACEMENT_VALUE(Category.X, "data exception", "22",
"invalid time zone displacement value", "009"),
/** 2200C: data exception: invalid use of escape character */
DATA_EXCEPTION_INVALID_USE_OF_ESCAPE_CHARACTER(Category.X, "data exception", "22",
"invalid use of escape character", "00C"),
/** 2201T: data exception: invalid XQuery option flag */
DATA_EXCEPTION_INVALID_XQUERY_OPTION_FLAG(Category.X, "data exception", "22",
"invalid XQuery option flag", "01T"),
/** 2201S: data exception: invalid XQuery regular expression */
DATA_EXCEPTION_INVALID_XQUERY_REGULAR_EXPRESSION(Category.X, "data exception", "22",
"invalid XQuery regular expression", "01S"),
/** 2201V: data exception: invalid XQuery replacement string */
DATA_EXCEPTION_INVALID_XQUERY_REPLACEMENT_STRING(Category.X, "data exception", "22",
"invalid XQuery replacement string", "01V"),
/** 2200G: data exception: most specific type mismatch */
DATA_EXCEPTION_MOST_SPECIFIC_TYPE_MISMATCH(Category.X, "data exception", "22",
"most specific type mismatch", "00G"),
/** 2200Q: data exception: multiset value overflow */
DATA_EXCEPTION_MULTISET_VALUE_OVERFLOW(Category.X, "data exception", "22",
"multiset value overflow", "00Q"),
/** 22029: data exception: noncharacter in UCS string */
DATA_EXCEPTION_NONCHARACTER_IN_UCS_STRING(Category.X, "data exception", "22",
"noncharacter in UCS string", "029"),
/** 2202D: data exception: null value substituted for mutator subject parameter */
DATA_EXCEPTION_NULL_VALUE_SUBSTITUTED_FOR_MUTATOR_SUBJECT_PARAMETER(Category.X, "data exception",
"22", "null value substituted for mutator subject parameter", "02D"),
/** 2201C: data exception: null row not permitted in table */
DATA_EXCEPTION_NULL_ROW_NOT_PERMITTED_IN_TABLE(Category.X, "data exception", "22",
"null row not permitted in table", "01C"),
/** 2200E: data exception: null value in array target */
DATA_EXCEPTION_NULL_VALUE_IN_ARRAY_TARGET(Category.X, "data exception", "22",
"null value in array target", "00E"),
/** 22002: data exception: null value, no indicator parameter */
DATA_EXCEPTION_NULL_VALUE_NO_INDICATOR_PARAMETER(Category.X, "data exception", "22",
"null value, no indicator parameter", "002"),
/** 22004: data exception: null value not allowed */
DATA_EXCEPTION_NULL_VALUE_NOT_ALLOWED(Category.X, "data exception", "22",
"null value not allowed", "004"),
/** 22003: data exception: numeric value out of range */
DATA_EXCEPTION_NUMERIC_VALUE_OUT_OF_RANGE(Category.X, "data exception", "22",
"numeric value out of range", "003"),
/** 2200H: data exception: sequence generator limit exceeded */
DATA_EXCEPTION_SEQUENCE_GENERATOR_LIMIT_EXCEEDED(Category.X, "data exception", "22",
"sequence generator limit exceeded", "00H"),
/** 2202K: data exception: skip to non-existent row */
DATA_EXCEPTION_SKIP_TO_NON_EXISTENT_ROW(Category.X, "data exception", "22",
"skip to non-existent row", "02K"),
/** 2202L: data exception: skip to first row of match */
DATA_EXCEPTION_SKIP_TO_FIRST_ROW_OF_MATCH(Category.X, "data exception", "22",
"skip to first row of match", "02L"),
/** 22026: data exception: string data, length mismatch */
DATA_EXCEPTION_STRING_DATA_LENGTH_MISMATCH(Category.X, "data exception", "22",
"string data, length mismatch", "026"),
/** 22001: data exception: string data, right truncation */
DATA_EXCEPTION_STRING_DATA_RIGHT_TRUNCATION(Category.X, "data exception", "22",
"string data, right truncation", "001"),
/** 22011: data exception: substring error */
DATA_EXCEPTION_SUBSTRING_ERROR(Category.X, "data exception", "22", "substring error", "011"),
/** 22027: data exception: trim error */
DATA_EXCEPTION_TRIM_ERROR(Category.X, "data exception", "22", "trim error", "027"),
/** 22024: data exception: unterminated C string */
DATA_EXCEPTION_UNTERMINATED_C_STRING(Category.X, "data exception", "22", "unterminated C string",
"024"),
/** 2200F: data exception: zero-length character string */
DATA_EXCEPTION_ZERO_LENGTH_CHARACTER_STRING(Category.X, "data exception", "22",
"zero-length character string", "00F"),
/** 2B000: dependent privilege descriptors still exist */
DEPENDENT_PRIVILEGE_DESCRIPTORS_STILL_EXIST_NO_SUBCLASS(Category.X,
"dependent privilege descriptors still exist", "2B", null, null),
/** 0Z000: diagnostics exception */
DIAGNOSTICS_EXCEPTION_NO_SUBCLASS(Category.X, "diagnostics exception", "0Z", null, null),
/** 0Z001: diagnostics exception: maximum number of stacked diagnostics areas exceeded */
DIAGNOSTICS_EXCEPTION_MAXIMUM_NUMBER_OF_DIAGNOSTICS_AREAS_EXCEEDED(Category.X,
"diagnostics exception", "0Z", "maximum number of stacked diagnostics areas exceeded", "001"),
/** 07000: dynamic SQL error */
DYNAMIC_SQL_ERROR_NO_SUBCLASS(Category.X, "dynamic SQL error", "07", null, null),
/** 07003: dynamic SQL error: cursor specification cannot be executed */
DYNAMIC_SQL_ERROR_CURSOR_SPECIFICATION_CANNOT_BE_EXECUTED(Category.X, "dynamic SQL error", "07",
"cursor specification cannot be executed", "003"),
/** 0700B: dynamic SQL error: data type transform function violation */
DYNAMIC_SQL_ERROR_DATA_TYPE_TRANSFORM_FUNCTION_VIOLATION(Category.X, "dynamic SQL error", "07",
"data type transform function violation", "00B"),
/** 0700D: dynamic SQL error: invalid DATA target */
DYNAMIC_SQL_ERROR_INVALID_DATA_TARGET(Category.X, "dynamic SQL error", "07",
"invalid DATA target", "00D"),
/** 0700F: dynamic SQL error: invalid DATETIME_INTERVAL_CODE */
DYNAMIC_SQL_ERROR_INVALID_DATETIME_INTERVAL_CODE(Category.X, "dynamic SQL error", "07",
"invalid DATETIME_INTERVAL_CODE", "00F"),
/** 07008: dynamic SQL error: invalid descriptor count */
DYNAMIC_SQL_ERROR_INVALID_DESCRIPTOR_COUNT(Category.X, "dynamic SQL error", "07",
"invalid descriptor count", "008"),
/** 07009: dynamic SQL error: invalid descriptor index */
DYNAMIC_SQL_ERROR_INVALID_DESCRIPTOR_INDEX(Category.X, "dynamic SQL error", "07",
"invalid descriptor index", "009"),
/** 0700E: dynamic SQL error: invalid LEVEL value */
DYNAMIC_SQL_ERROR_INVALID_LEVEL_VALUE(Category.X, "dynamic SQL error", "07",
"invalid LEVEL value", "00E"),
/** 07005: dynamic SQL error: prepared statement not a cursor specification */
DYNAMIC_SQL_ERROR_PREPARED_STATEMENT_NOT_A_CURSOR_SPECIFICATION(
Category.X, "dynamic SQL error", "07",
"prepared statement not a cursor specification", "005"),
/** 07006: dynamic SQL error: restricted data type attribute violation */
DYNAMIC_SQL_ERROR_RESTRICTED_DATA_TYPE_ATTRIBUTE_VIOLATION(
Category.X, "dynamic SQL error", "07", "restricted data type attribute violation", "006"),
/** 0700C: dynamic SQL error: undefined DATA value */
DYNAMIC_SQL_ERROR_UNDEFINED_DATA_VALUE(Category.X, "dynamic SQL error", "07",
"undefined DATA value", "00C"),
/** 07001: dynamic SQL error: using clause does not match dynamic parameter specifications */
DYNAMIC_SQL_ERROR_USING_CLAUSE_DOES_NOT_MATCH_DYNAMIC_PARAMETER_SPEC(Category.X,
"dynamic SQL error", "07", "using clause does not match dynamic parameter specifications",
"001"),
/** 07002: dynamic SQL error: using clause does not match target specifications */
DYNAMIC_SQL_ERROR_USING_CLAUSE_DOES_NOT_MATCH_TARGET_SPEC(Category.X,
"dynamic SQL error", "07", "using clause does not match target specifications", "002"),
/** 07004: dynamic SQL error: using clause required for dynamic parameters */
DYNAMIC_SQL_ERROR_USING_CLAUSE_REQUIRED_FOR_DYNAMIC_PARAMETERS(Category.X, "dynamic SQL error",
"07", "using clause required for dynamic parameters", "004"),
/** 07007: dynamic SQL error: using clause required for result fields */
DYNAMIC_SQL_ERROR_USING_CLAUSE_REQUIRED_FOR_RESULT_FIELDS(Category.X, "dynamic SQL error", "07",
"using clause required for result fields", "007"),
/** 38000: external routine exception */
EXTERNAL_ROUTINE_EXCEPTION_NO_SUBCLASS(Category.X, "external routine exception", "38", null,
null),
/** 38001: external routine exception: containing SQL not permitted */
EXTERNAL_ROUTINE_EXCEPTION_CONTAINING_SQL_NOT_PERMITTED(Category.X, "external routine exception",
"38", "containing SQL not permitted", "001"),
/** 38002: external routine exception: modifying SQL-data not permitted */
EXTERNAL_ROUTINE_EXCEPTION_MODIFYING_SQL_DATA_NOT_PERMITTED(Category.X,
"external routine exception", "38", "modifying SQL-data not permitted", "002"),
/** 38003: external routine exception: prohibited SQL-statement attempted */
EXTERNAL_ROUTINE_EXCEPTION_PROHIBITED_SQL_STATEMENT_ATTEMPTED(Category.X,
"external routine exception", "38", "prohibited SQL-statement attempted", "003"),
/** 38004: external routine exception: reading SQL-data not permitted */
EXTERNAL_ROUTINE_EXCEPTION_READING_SQL_DATA_NOT_PERMITTED(Category.X,
"external routine exception", "38", "reading SQL-data not permitted", "004"),
/** 39000: external routine invocation exception */
EXTERNAL_ROUTINE_INVOCATION_EXCEPTION_NO_SUBCLASS(Category.X,
"external routine invocation exception", "39", null, null),
/** 39004: external routine invocation exception: null value not allowed */
EXTERNAL_ROUTINE_INVOCATION_EXCEPTION_NULL_VALUE_NOT_ALLOWED(Category.X,
"external routine invocation exception", "39", "null value not allowed", "004"),
/** 0A000: feature not supported */
FEATURE_NOT_SUPPORTED_NO_SUBCLASS(Category.X, "feature not supported", "0A", null, null),
/** 0A001: feature not supported: multiple server transactions */
FEATURE_NOT_SUPPORTED_MULTIPLE_ENVIRONMENT_TRANSACTIONS(Category.X, "feature not supported", "0A",
"multiple server transactions", "001"),
/** 23000: integrity constraint violation */
INTEGRITY_CONSTRAINT_VIOLATION_NO_SUBCLASS(Category.X, "integrity constraint violation", "23",
null, null),
/** 23001: integrity constraint violation: restrict violation */
INTEGRITY_CONSTRAINT_VIOLATION_RESTRICT_VIOLATION(Category.X, "integrity constraint violation",
"23", "restrict violation", "001"),
/** 28000: invalid authorization specification */
INVALID_AUTHORIZATION_SPECIFICATION_NO_SUBCLASS(Category.X, "invalid authorization specification",
"28", null, null),
/** 3D000: invalid catalog name */
INVALID_CATALOG_NAME_NO_SUBCLASS(Category.X, "invalid catalog name", "3D", null, null),
/** 2C000: invalid character set name */
INVALID_CHARACTER_SET_NAME_NO_SUBCLASS(Category.X, "invalid character set name", "2C", null,
null),
/** 2C001: invalid character set name: cannot drop SQL-session default character set */
INVALID_CHARACTER_SET_NAME_CANNOT_DROP_SQLSESSION_DEFAULT_CHARACTER_SET(Category.X,
"invalid character set name", "2C", "cannot drop SQL-session default character set", "001"),
/** 35000: invalid condition number */
INVALID_CONDITION_NUMBER_NO_SUBCLASS(Category.X, "invalid condition number", "35", null, null),
/** 2E000: invalid connection name */
INVALID_CONNECTION_NAME_NO_SUBCLASS(Category.X, "invalid connection name", "2E", null, null),
/** 34000: invalid cursor name */
INVALID_CURSOR_NAME_NO_SUBCLASS(Category.X, "invalid cursor name", "34", null, null),
/** 24000: invalid cursor state */
INVALID_CURSOR_STATE_NO_SUBCLASS(Category.X, "invalid cursor state", "24", null, null),
/** 0L000: invalid grantor */
INVALID_GRANTOR_STATE_NO_SUBCLASS(Category.X, "invalid grantor", "0L", null, null),
/** 0P000: invalid role specification */
INVALID_ROLE_SPECIFICATION(Category.X, "invalid role specification", "0P", null,
null),
/** 3F000: invalid schema name */
INVALID_SCHEMA_NAME_NO_SUBCLASS(Category.X, "invalid schema name", "3F", null, null),
/** 0E000: invalid schema name list specification */
INVALID_SCHEMA_NAME_LIST_SPECIFICATION_NO_SUBCLASS(Category.X,
"invalid schema name list specification", "0E", null, null),
/** 2H000: invalid collation name */
INVALID_COLLATION_NAME_NO_SUBCLASS(Category.X, "invalid collation name", "2H", null, null),
/** 33000: invalid SQL descriptor name */
INVALID_SQL_DESCRIPTOR_NAME_NO_SUBCLASS(Category.X, "invalid SQL descriptor name", "33", null,
null),
/** 0M000: invalid SQL-invoked procedure reference */
INVALID_SQL_INVOKED_PROCEDURE_REFERENCE_NO_SUBCLASS(Category.X,
"invalid SQL-invoked procedure reference", "0M", null, null),
/** 26000: invalid SQL statement name */
INVALID_SQL_STATEMENT_NAME_NO_SUBCLASS(Category.X, "invalid SQL statement name", "26", null,
null),
/** 30000: invalid SQL statement identifier */
INVALID_SQL_STATEMENT_IDENTIFIER_NO_SUBCLASS(Category.X, "invalid SQL statement identifier", "30",
null, null),
/** 0D000: invalid target type specification */
INVALID_TARGET_TYPE_SPECIFICATION_NO_SUBCLASS(Category.X, "invalid target type specification",
"0D", null, null),
/** 25000: invalid transaction state */
INVALID_TRANSACTION_STATE_NO_SUBCLASS(Category.X, "invalid transaction state", "25", null, null),
/** 25001: invalid transaction state: active SQL-transaction */
INVALID_TRANSACTION_STATE_ACTIVE_SQL_TRANSACTION(Category.X, "invalid transaction state", "25",
"active SQL-transaction", "001"),
/** 25002: invalid transaction state: branch transaction already active */
INVALID_TRANSACTION_STATE_BRANCH_TRANSACTION_ALREADY_ACTIVE(Category.X,
"invalid transaction state", "25", "branch transaction already active", "002"),
/** 25008: invalid transaction state: held cursor requires same isolation level */
INVALID_TRANSACTION_STATE_HELD_CURSOR_REQUIRES_SAME_ISOLATION_LEVEL(Category.X,
"invalid transaction state", "25", "held cursor requires same isolation level", "008"),
/** 25003: invalid transaction state: inappropriate access mode for branch transaction */
INVALID_TRANSACTION_STATE_INAPPROPRIATE_ACCESS_MODE_FOR_BRANCH_TRANSACTION(Category.X,
"invalid transaction state", "25", "inappropriate access mode for branch transaction", "003"),
/** 25004: invalid transaction state: inappropriate isolation level for branch transaction */
INVALID_TRANSACTION_STATE_INAPPROPRIATE_ISOLATION_LEVEL_FOR_BRANCH_TRANSACTION(Category.X,
"invalid transaction state", "25", "inappropriate isolation level for branch transaction",
"004"),
/** 25005: invalid transaction state: no active SQL-transaction for branch transaction */
INVALID_TRANSACTION_STATE_NO_ACTIVE_SQL_TRANSACTION_FOR_BRANCH_TRANSACTION(Category.X,
"invalid transaction state", "25", "no active SQL-transaction for branch transaction", "005"),
/** 25006: invalid transaction state: read-only SQL-transaction */
INVALID_TRANSACTION_STATE_READ_ONLY_SQL_TRANSACTION(Category.X, "invalid transaction state", "25",
"read-only SQL-transaction", "006"),
/** 25007: invalid transaction state: schema and data statement mixing not supported */
INVALID_TRANSACTION_STATE_SCHEMA_AND_DATA_STATEMENT_MIXING_NOT_SUPPORTED(Category.X,
"invalid transaction state", "25", "schema and data statement mixing not supported", "007"),
/** 2D000: invalid transaction termination */
INVALID_TRANSACTION_TERMINATION_NO_SUBCLASS(Category.X, "invalid transaction termination", "2D",
null, null),
/** 0S000: invalid transform group name specification */
INVALID_TRANSFORM_GROUP_NAME_SPECIFICATION_NO_SUBCLASS(Category.X,
"invalid transform group name specification", "0S", null, null),
/** 0F000: locator exception */
LOCATOR_EXCEPTION_NO_SUBCLASS(Category.X, "locator exception", "0F", null, null),
/** 0F001: locator exception: invalid specification */
LOCATOR_EXCEPTION_INVALID_SPECIFICATION(Category.X, "locator exception", "0F",
"invalid specification", "001"),
/** 02000: no data */
NO_DATA_NO_SUBCLASS(Category.N, "no data", "02", null, null),
/** 02001: no data: no additional result sets returned */
NO_DATA_NO_ADDITIONAL_RESULT_SETS_RETURNED(Category.N, "no data", "02",
"no additional result sets returned", "001"),
/** 0W000: prohibited statement encountered during trigger execution */
PROHIBITED_STATEMENT_DURING_TRIGGER_EXECUTION_NO_SUBCLASS(Category.X,
"prohibited statement encountered during trigger execution", "0W", null, null),
/** 0W001: prohibited statement encountered during trigger execution: modify table modified by
* data change delta table */
PROHIBITED_STATEMENT_DURING_TRIGGER_EXECUTION_MODIFY_TABLE_MODIFIED_BY_DATA_CHANGE_DELTA_TABLE(
Category.X, "prohibited statement encountered during trigger execution", "0W",
"modify table modified by data change delta table", "001"),
/** HZ: Remote Database Access
*
* <p>(See Table 12, 'SQLSTATE class and subclass values for RDA-specific conditions' in
* [ISO9579], Subclause 8.1, 'Exception codes for RDA-specific Conditions', for the definition of
* protocol subconditions and subclass code values.) */
REMOTE_DATABASE_ACCESS_NO_SUBCLASS(Category.X, "Remote Database Access", "HZ", null, null),
/** 3B000: savepoint exception */
SAVEPOINT_EXCEPTION_NO_SUBCLASS(Category.X, "savepoint exception", "3B", null, null),
/** 3B001: savepoint exception: invalid specification */
SAVEPOINT_EXCEPTION_INVALID_SPECIFICATION(Category.X, "savepoint exception", "3B",
"invalid specification", "001"),
/** 3B002: savepoint exception: too many */
SAVEPOINT_EXCEPTION_TOO_MANY(Category.X, "savepoint exception", "3B", "too many", "002"),
/** 2F000: SQL routine exception */
SQL_ROUTINE_EXCEPTION_NO_SUBCLASS(Category.X, "SQL routine exception", "2F", null, null),
/** 2F005: SQL routine exception: function executed no return statement */
SQL_ROUTINE_EXCEPTION_FUNCTION_EXECUTED_NO_RETURN_STATEMENT(Category.X, "SQL routine exception",
"2F", "function executed no return statement", "005"),
/** 2F002: SQL routine exception: modifying SQL-data not permitted */
SQL_ROUTINE_EXCEPTION_MODIFYING_SQL_DATA_NOT_PERMITTED(Category.X, "SQL routine exception", "2F",
"modifying SQL-data not permitted", "002"),
/** 2F003: SQL routine exception: prohibited SQL-statement attempted */
SQL_ROUTINE_EXCEPTION_PROHIBITED_SQL_STATEMENT_ATTEMPTED(Category.X, "SQL routine exception",
"2F", "prohibited SQL-statement attempted", "003"),
/** 2F004: SQL routine exception: reading SQL-data not permitted */
SQL_ROUTINE_EXCEPTION_READING_SQL_DATA_NOT_PERMITTED(Category.X, "SQL routine exception", "2F",
"reading SQL-data not permitted", "004"),
/** 00000: successful completion */
SUCCESSFUL_COMPLETION_NO_SUBCLASS(Category.S, "successful completion", "00", null, null),
/** 42000: syntax error or access rule violation */
SYNTAX_ERROR_OR_ACCESS_RULE_VIOLATION_NO_SUBCLASS(Category.X,
"syntax error or access rule violation", "42", null, null),
/** 2A000: syntax error or access rule violation */
SYNTAX_ERROR_OR_ACCESS_RULE_VIOLATION_IN_DIRECT_STATEMENT_NO_SUBCLASS(Category.X,
"syntax error or access rule violation in direct statement", "2A", null, null),
/** 37000: syntax error or access rule violation */
SYNTAX_ERROR_OR_ACCESS_RULE_VIOLATION_IN_DYNAMIC_STATEMENT_NO_SUBCLASS(Category.X,
"syntax error or access rule violation in dynamic statement", "37", null, null),
/** 0T000: target table disagrees with cursor specification */
TARGET_TABLE_DISAGREES_WITH_CURSOR_SPECIFICATION_NO_SUBCLASS(Category.X,
"target table disagrees with cursor specification", "0T", null, null),
/** 40000: transaction rollback */
TRANSACTION_ROLLBACK_NO_SUBCLASS(Category.X, "transaction rollback", "40", null, null),
/** 40002: transaction rollback: integrity constraint violation */
TRANSACTION_ROLLBACK_INTEGRITY_CONSTRAINT_VIOLATION(Category.X, "transaction rollback", "40",
"integrity constraint violation", "002"),
/** 40001: transaction rollback: serialization failure */
TRANSACTION_ROLLBACK_SERIALIZATION_FAILURE(Category.X, "transaction rollback", "40",
"serialization failure", "001"),
/** 40003: transaction rollback: statement completion unknown */
TRANSACTION_ROLLBACK_STATEMENT_COMPLETION_UNKNOWN(Category.X, "transaction rollback", "40",
"statement completion unknown", "003"),
/** 40004: transaction rollback: triggered action exception */
TRANSACTION_ROLLBACK_TRIGGERED_ACTION_EXCEPTION(Category.X, "transaction rollback", "40",
"triggered action exception", "004"),
/** 09000: triggered action exception */
TRIGGERED_ACTION_EXCEPTION_NO_SUBCLASS(Category.X, "triggered action exception", "09", null,
null),
/** 27000: triggered data change violation */
TRIGGERED_DATA_CHANGE_VIOLATION_NO_SUBCLASS(Category.X, "triggered data change violation", "27",
null, null),
/** 27001: triggered data change violation: modify table modified by data change delta table */
TRIGGERED_DATA_CHANGE_VIOLATION_MODIFY_TABLE_MODIFIED_BY_DATA_CHANGE_DELTA_TABLE(Category.X,
"triggered data change violation", "27", "modify table modified by data change delta table",
"001"),
/** 01000: warning */
WARNING_NO_SUBCLASS(Category.W, "warning", "01", null, null),
/** 0100D: warning: additional result sets returned */
WARNING_ADDITIONAL_RESULT_SETS_RETURNED(Category.W, "warning", "01",
"additional result sets returned", "00D"),
/** 0102F: warning: array data, right truncation */
WARNING_ARRAY_DATA_RIGHT_TRUNCATION(Category.W, "warning", "01", "array data, right truncation",
"02F"),
/** 0100E: warning: attempt to return too many result sets */
WARNING_ATTEMPT_TO_RETURN_TOO_MANY_RESULT_SETS(Category.W, "warning", "01",
"attempt to return too many result sets", "00E"),
/** 01001: warning: cursor operation conflict */
WARNING_CURSOR_OPERATION_CONFLICT(Category.W, "warning", "01", "cursor operation conflict",
"001"),
/** 0100B: warning: default value too long for information schema */
WARNING_DEFAULT_VALUE_TOO_LONG_FOR_INFORMATION_SCHEMA(Category.W, "warning", "01",
"default value too long for information schema", "00B"),
/** 01002: warning: disconnect error */
WARNING_DISCONNECT_ERROR(Category.W, "warning", "01", "disconnect error", "002"),
/** 01005: warning: insufficient item descriptor areas */
WARNING_INSUFFICIENT_ITEM_DESCRIPTOR_AREAS(Category.W, "warning", "01",
"insufficient item descriptor areas", "005"),
/** 01012: warning: invalid number of conditions */
WARNING_INVALID_NUMBER_OF_CONDITIONS(Category.W, "warning", "01", "invalid number of conditions",
"012"),
/** 01003: warning: null value eliminated in set function */
WARNING_NULL_VALUE_ELIMINATED_IN_SET_FUNCTION(Category.W, "warning", "01",
"null value eliminated in set function", "003"),
/** 01007: warning: privilege not granted */
WARNING_PRIVILEGE_NOT_GRANTED(Category.W, "warning", "01", "privilege not granted", "007"),
/** 01006: warning: privilege not revoked */
WARNING_PRIVILEGE_NOT_REVOKED(Category.W, "warning", "01", "privilege not revoked", "006"),
/** 0100A: warning: query expression too long for information schema */
WARNING_QUERY_EXPRESSION_TOO_LONG_FOR_INFORMATION_SCHEMA(Category.W, "warning", "01",
"query expression too long for information schema", "00A"),
/** 0100C: warning: result sets returned */
WARNING_DYNAMIC_RESULT_SETS_RETURNED(Category.W, "warning", "01", "result sets returned", "00C"),
/** 01009: warning: search condition too long for information schema */
WARNING_SEARCH_CONDITION_TOO_LONG_FOR_INFORMATION_SCHEMA(Category.W, "warning", "01",
"search condition too long for information schema", "009"),
/** 0100F: warning: statement too long for information schema */
WARNING_STATEMENT_TOO_LONG_FOR_INFORMATION_SCHEMA(Category.W, "warning", "01",
"statement too long for information schema", "00F"),
/** 01004: warning: string data, right truncation */
WARNING_STRING_DATA_RIGHT_TRUNCATION_WARNING(Category.W, "warning", "01",
"string data, right truncation", "004"),
/** 44000: with check option violation */
WITH_CHECK_OPTION_VIOLATION_NO_SUBCLASS(Category.X, "with check option violation", "44", null,
null);
public final Category category;
public final String condition;
public final String klass;
public final String subCondition;
public final String subClass;
public final String code;
/** Alias for backwards compatibility with previous versions of SQL spec. */
public static final SqlState INVALID_SQL_STATEMENT =
INVALID_SQL_STATEMENT_IDENTIFIER_NO_SUBCLASS;
public static final Map<String, SqlState> BY_CODE;
static {
Map<String, SqlState> m = new HashMap<>();
for (SqlState s : values()) {
m.put(s.code, s);
}
BY_CODE = Collections.unmodifiableMap(m);
}
SqlState(Category category, String condition, String klass, String subCondition,
String subClass) {
this.category = category;
this.condition = condition;
this.klass = klass;
this.subCondition = subCondition;
this.subClass = subClass;
this.code = klass + (subClass == null ? "000" : subClass);
}
/** Validates the data, and generates the HTML table. */
private static void main(String[] args) {
PrintWriter pw = new PrintWriter(
new BufferedWriter(
new OutputStreamWriter(System.out, StandardCharsets.UTF_8)));
pw.println(" * <table>");
SqlState parent = null;
for (SqlState s : values()) {
assert s.klass.length() == 2;
assert s.subClass == null || s.subClass.length() == 3;
if (s.subClass == null) {
assert s.subCondition == null;
parent = s;
} else {
assert parent != null;
assert s.subCondition != null;
assert s.category == parent.category;
assert s.klass.equals(parent.klass);
assert s.condition.equals(parent.condition);
}
pw.println(" * <tr>");
pw.println(" * <td>" + (parent == s ? s.category : "&nbsp;") + "</td>");
pw.println(" * <td>" + (parent == s ? s.condition : "&nbsp;") + "</td>");
pw.println(" * <td>" + (parent == s ? s.klass : "&nbsp;") + "</td>");
pw.println(" * <td>" + (s.subCondition == null ? "(no subclass)" : s.subCondition)
+ "</td>");
pw.println(" * <td>" + (s.subCondition == null ? "000" : s.subClass) + "</td>");
pw.println(" * </tr>");
}
pw.println(" * </table>");
pw.close();
}
/** Severity types. */
enum Category {
/** Success (class 00). */
S,
/** Warning (class 01). */
W,
/** No data (class 02). */
N,
/** Exception (all other classes). */
X,
}
}
// End SqlState.java