PageRenderTime 58ms CodeModel.GetById 26ms RepoModel.GetById 0ms app.codeStats 0ms

/mysql-connector-java-3.0.17-ga/com/mysql/jdbc/SQLError.java

https://github.com/negorath/ntnu-prosjekt1
Java | 664 lines | 444 code | 67 blank | 153 comment | 3 complexity | fa8a6e6474790317bf239a6bfe3d8821 MD5 | raw file
  1. /*
  2. Copyright (C) 2002-2004 MySQL AB
  3. This program is free software; you can redistribute it and/or modify
  4. it under the terms of version 2 of the GNU General Public License as
  5. published by the Free Software Foundation.
  6. There are special exceptions to the terms and conditions of the GPL
  7. as it is applied to this software. View the full text of the
  8. exception exception in file EXCEPTIONS-CONNECTOR-J in the directory of this
  9. software distribution.
  10. This program is distributed in the hope that it will be useful,
  11. but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. GNU General Public License for more details.
  14. You should have received a copy of the GNU General Public License
  15. along with this program; if not, write to the Free Software
  16. Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  17. */
  18. package com.mysql.jdbc;
  19. import java.sql.DataTruncation;
  20. import java.sql.SQLException;
  21. import java.sql.SQLWarning;
  22. import java.util.HashMap;
  23. import java.util.Hashtable;
  24. import java.util.Iterator;
  25. import java.util.Map;
  26. import java.util.TreeMap;
  27. /**
  28. * SQLError is a utility class that maps MySQL error codes to X/Open error
  29. * codes as is required by the JDBC spec.
  30. *
  31. * @author Mark Matthews
  32. * @version $Id: SQLError.java,v 1.6.2.8 2004/12/21 23:18:46 mmatthew Exp $
  33. */
  34. public class SQLError {
  35. public static final String SQL_STATE_TIMEOUT_EXPIRED = "S1T00";
  36. public static final String SQL_STATE_DRIVER_NOT_CAPABLE = "S1C00";
  37. public static final String SQL_STATE_ILLEGAL_ARGUMENT = "S1009";
  38. public static final String SQL_STATE_INVALID_COLUMN_NUMBER = "S1002";
  39. public static final String SQL_STATE_MEMORY_ALLOCATION_FAILURE = "S1001";
  40. public static final String SQL_STATE_GENERAL_ERROR = "S1000";
  41. public static final String SQL_STATE_NO_DEFAULT_FOR_COLUMN = "S0023";
  42. public static final String SQL_STATE_COLUMN_NOT_FOUND = "S0022";
  43. public static final String SQL_STATE_COLUMN_ALREADY_EXISTS = "S0021";
  44. public static final String SQL_STATE_INDEX_NOT_FOUND = "S0012";
  45. public static final String SQL_STATE_INDEX_ALREADY_EXISTS = "S0011";
  46. public static final String SQL_STATE_BASE_TABLE_NOT_FOUND = "S0002";
  47. public static final String SQL_STATE_BASE_TABLE_OR_VIEW_ALREADY_EXISTS = "S0001";
  48. public static final String SQL_STATE_BASE_TABLE_OR_VIEW_NOT_FOUND = "42S02";
  49. public static final String SQL_STATE_SYNTAX_ERROR = "42000";
  50. public static final String SQL_STATE_DATETIME_FIELD_OVERFLOW = "22008";
  51. public static final String SQL_STATE_NUMERIC_VALUE_OUT_OF_RANGE = "22003";
  52. public static final String SQL_STATE_INSERT_VALUE_LIST_NO_MATCH_COL_LIST = "21S01";
  53. public static final String SQL_STATE_DIVISION_BY_ZERO = "22012";
  54. public static final String SQL_STATE_INVALID_AUTH_SPEC = "28000";
  55. public static final String SQL_STATE_DEADLOCK = "41000";
  56. public static final String SQL_STATE_CONNECTION_FAIL_DURING_TX = "08007";
  57. public static final String SQL_STATE_CONNECTION_REJECTED = "08004";
  58. public static final String SQL_STATE_UNABLE_TO_CONNECT_TO_DATASOURCE = "08001";
  59. public static final String SQL_STATE_CONNECTION_IN_USE = "08002";
  60. public static final String SQL_STATE_CONNECTION_NOT_OPEN = "08003";
  61. public static final String SQL_STATE_WRONG_NO_OF_PARAMETERS = "07001";
  62. public static final String SQL_STATE_MORE_THAN_ONE_ROW_UPDATED_OR_DELETED = "01S04";
  63. public static final String SQL_STATE_NO_ROWS_UPDATED_OR_DELETED = "01S03";
  64. public static final String SQL_STATE_ERROR_IN_ROW = "01S01";
  65. public static final String SQL_STATE_COMMUNICATION_LINK_FAILURE = "08S01";
  66. public static final String SQL_STATE_INVALID_CONNECTION_ATTRIBUTE = "01S00";
  67. public static final String SQL_STATE_PRIVILEGE_NOT_REVOKED = "01006";
  68. public static final String SQL_STATE_DATE_TRUNCATED = "01004";
  69. public static final String SQL_STATE_DISCONNECT_ERROR = "01002";
  70. public static final String SQL_STATE_INTEGRITY_CONSTRAINT_VIOLATION = "23000";
  71. private static Hashtable mysqlToSqlState;
  72. private static Hashtable mysqlToSql99State;
  73. private static Hashtable sqlStateMessages;
  74. static {
  75. sqlStateMessages = new Hashtable();
  76. sqlStateMessages.put(SQL_STATE_DISCONNECT_ERROR, "Disconnect error");
  77. sqlStateMessages.put(SQL_STATE_DATE_TRUNCATED, "Data truncated");
  78. sqlStateMessages.put(SQL_STATE_PRIVILEGE_NOT_REVOKED,
  79. "Privilege not revoked");
  80. sqlStateMessages.put(SQL_STATE_INVALID_CONNECTION_ATTRIBUTE,
  81. "Invalid connection string attribute");
  82. sqlStateMessages.put(SQL_STATE_ERROR_IN_ROW, "Error in row");
  83. sqlStateMessages.put(SQL_STATE_NO_ROWS_UPDATED_OR_DELETED,
  84. "No rows updated or deleted");
  85. sqlStateMessages.put(SQL_STATE_MORE_THAN_ONE_ROW_UPDATED_OR_DELETED,
  86. "More than one row updated or deleted");
  87. sqlStateMessages.put(SQL_STATE_WRONG_NO_OF_PARAMETERS,
  88. "Wrong number of parameters");
  89. sqlStateMessages.put(SQL_STATE_UNABLE_TO_CONNECT_TO_DATASOURCE,
  90. "Unable to connect to data source");
  91. sqlStateMessages.put(SQL_STATE_CONNECTION_IN_USE, "Connection in use");
  92. sqlStateMessages.put(SQL_STATE_CONNECTION_NOT_OPEN,
  93. "Connection not open");
  94. sqlStateMessages.put(SQL_STATE_CONNECTION_REJECTED,
  95. "Data source rejected establishment of connection");
  96. sqlStateMessages.put(SQL_STATE_CONNECTION_FAIL_DURING_TX,
  97. "Connection failure during transaction");
  98. sqlStateMessages.put(SQL_STATE_COMMUNICATION_LINK_FAILURE,
  99. "Communication link failure");
  100. sqlStateMessages.put(SQL_STATE_INSERT_VALUE_LIST_NO_MATCH_COL_LIST,
  101. "Insert value list does not match column list");
  102. sqlStateMessages.put(SQL_STATE_NUMERIC_VALUE_OUT_OF_RANGE,
  103. "Numeric value out of range");
  104. sqlStateMessages.put(SQL_STATE_DATETIME_FIELD_OVERFLOW,
  105. "Datetime field overflow");
  106. sqlStateMessages.put(SQL_STATE_DIVISION_BY_ZERO, "Division by zero");
  107. sqlStateMessages.put(SQL_STATE_DEADLOCK,
  108. "Deadlock found when trying to get lock; Try restarting transaction");
  109. sqlStateMessages.put(SQL_STATE_INVALID_AUTH_SPEC,
  110. "Invalid authorization specification");
  111. sqlStateMessages.put(SQL_STATE_SYNTAX_ERROR,
  112. "Syntax error or access violation");
  113. sqlStateMessages.put(SQL_STATE_BASE_TABLE_OR_VIEW_NOT_FOUND,
  114. "Base table or view not found");
  115. sqlStateMessages.put(SQL_STATE_BASE_TABLE_OR_VIEW_ALREADY_EXISTS,
  116. "Base table or view already exists");
  117. sqlStateMessages.put(SQL_STATE_BASE_TABLE_NOT_FOUND,
  118. "Base table not found");
  119. sqlStateMessages.put(SQL_STATE_INDEX_ALREADY_EXISTS,
  120. "Index already exists");
  121. sqlStateMessages.put(SQL_STATE_INDEX_NOT_FOUND, "Index not found");
  122. sqlStateMessages.put(SQL_STATE_COLUMN_ALREADY_EXISTS,
  123. "Column already exists");
  124. sqlStateMessages.put(SQL_STATE_COLUMN_NOT_FOUND, "Column not found");
  125. sqlStateMessages.put(SQL_STATE_NO_DEFAULT_FOR_COLUMN,
  126. "No default for column");
  127. sqlStateMessages.put(SQL_STATE_GENERAL_ERROR, "General error");
  128. sqlStateMessages.put(SQL_STATE_MEMORY_ALLOCATION_FAILURE,
  129. "Memory allocation failure");
  130. sqlStateMessages.put(SQL_STATE_INVALID_COLUMN_NUMBER,
  131. "Invalid column number");
  132. sqlStateMessages.put(SQL_STATE_ILLEGAL_ARGUMENT,
  133. "Invalid argument value");
  134. sqlStateMessages.put(SQL_STATE_DRIVER_NOT_CAPABLE, "Driver not capable");
  135. sqlStateMessages.put(SQL_STATE_TIMEOUT_EXPIRED, "Timeout expired");
  136. sqlStateMessages.put(SQL_STATE_INTEGRITY_CONSTRAINT_VIOLATION, "Duplicate key or integrity constraint violation");
  137. //
  138. // Map MySQL error codes to X/Open error codes
  139. //
  140. mysqlToSqlState = new Hashtable();
  141. //
  142. // Communications Errors
  143. //
  144. // ER_CON_COUNT_ERROR 1040
  145. // ER_BAD_HOST_ERROR 1042
  146. // ER_HANDSHAKE_ERROR 1043
  147. // ER_UNKNOWN_COM_ERROR 1047
  148. // ER_IPSOCK_ERROR 1081
  149. //
  150. mysqlToSqlState.put(new Integer(1040), SQL_STATE_CONNECTION_REJECTED);
  151. mysqlToSqlState.put(new Integer(1042), SQL_STATE_CONNECTION_REJECTED);
  152. mysqlToSqlState.put(new Integer(1043), SQL_STATE_CONNECTION_REJECTED);
  153. mysqlToSqlState.put(new Integer(1047),
  154. SQL_STATE_COMMUNICATION_LINK_FAILURE);
  155. mysqlToSqlState.put(new Integer(1081),
  156. SQL_STATE_COMMUNICATION_LINK_FAILURE);
  157. // ER_HOST_IS_BLOCKED 1129
  158. // ER_HOST_NOT_PRIVILEGED 1130
  159. mysqlToSqlState.put(new Integer(1129), SQL_STATE_CONNECTION_REJECTED);
  160. mysqlToSqlState.put(new Integer(1130), SQL_STATE_CONNECTION_REJECTED);
  161. //
  162. // Authentication Errors
  163. //
  164. // ER_ACCESS_DENIED_ERROR 1045
  165. //
  166. mysqlToSqlState.put(new Integer(1045), SQL_STATE_INVALID_AUTH_SPEC);
  167. //
  168. // Resource errors
  169. //
  170. // ER_CANT_CREATE_FILE 1004
  171. // ER_CANT_CREATE_TABLE 1005
  172. // ER_CANT_LOCK 1015
  173. // ER_DISK_FULL 1021
  174. // ER_OUT_OF_RESOURCES 1041
  175. //
  176. // Out-of-memory errors
  177. //
  178. // ER_OUTOFMEMORY 1037
  179. // ER_OUT_OF_SORTMEMORY 1038
  180. //
  181. mysqlToSqlState.put(new Integer(1037),
  182. SQL_STATE_MEMORY_ALLOCATION_FAILURE);
  183. mysqlToSqlState.put(new Integer(1038),
  184. SQL_STATE_MEMORY_ALLOCATION_FAILURE);
  185. //
  186. // Syntax Errors
  187. //
  188. // ER_PARSE_ERROR 1064
  189. // ER_EMPTY_QUERY 1065
  190. //
  191. mysqlToSqlState.put(new Integer(1064), SQL_STATE_SYNTAX_ERROR);
  192. mysqlToSqlState.put(new Integer(1065), SQL_STATE_SYNTAX_ERROR);
  193. //
  194. // Invalid argument errors
  195. //
  196. // ER_WRONG_FIELD_WITH_GROUP 1055
  197. // ER_WRONG_GROUP_FIELD 1056
  198. // ER_WRONG_SUM_SELECT 1057
  199. // ER_TOO_LONG_IDENT 1059
  200. // ER_DUP_FIELDNAME 1060
  201. // ER_DUP_KEYNAME 1061
  202. // ER_DUP_ENTRY 1062
  203. // ER_WRONG_FIELD_SPEC 1063
  204. // ER_NONUNIQ_TABLE 1066
  205. // ER_INVALID_DEFAULT 1067
  206. // ER_MULTIPLE_PRI_KEY 1068
  207. // ER_TOO_MANY_KEYS 1069
  208. // ER_TOO_MANY_KEY_PARTS 1070
  209. // ER_TOO_LONG_KEY 1071
  210. // ER_KEY_COLUMN_DOES_NOT_EXIST 1072
  211. // ER_BLOB_USED_AS_KEY 1073
  212. // ER_TOO_BIG_FIELDLENGTH 1074
  213. // ER_WRONG_AUTO_KEY 1075
  214. // ER_NO_SUCH_INDEX 1082
  215. // ER_WRONG_FIELD_TERMINATORS 1083
  216. // ER_BLOBS_AND_NO_TERMINATED 1084
  217. //
  218. mysqlToSqlState.put(new Integer(1055), SQL_STATE_ILLEGAL_ARGUMENT);
  219. mysqlToSqlState.put(new Integer(1056), SQL_STATE_ILLEGAL_ARGUMENT);
  220. mysqlToSqlState.put(new Integer(1057), SQL_STATE_ILLEGAL_ARGUMENT);
  221. mysqlToSqlState.put(new Integer(1059), SQL_STATE_ILLEGAL_ARGUMENT);
  222. mysqlToSqlState.put(new Integer(1060), SQL_STATE_ILLEGAL_ARGUMENT);
  223. mysqlToSqlState.put(new Integer(1061), SQL_STATE_ILLEGAL_ARGUMENT);
  224. mysqlToSqlState.put(new Integer(1062), SQL_STATE_INTEGRITY_CONSTRAINT_VIOLATION);
  225. mysqlToSqlState.put(new Integer(1063), SQL_STATE_ILLEGAL_ARGUMENT);
  226. mysqlToSqlState.put(new Integer(1066), SQL_STATE_ILLEGAL_ARGUMENT);
  227. mysqlToSqlState.put(new Integer(1067), SQL_STATE_ILLEGAL_ARGUMENT);
  228. mysqlToSqlState.put(new Integer(1068), SQL_STATE_ILLEGAL_ARGUMENT);
  229. mysqlToSqlState.put(new Integer(1069), SQL_STATE_ILLEGAL_ARGUMENT);
  230. mysqlToSqlState.put(new Integer(1070), SQL_STATE_ILLEGAL_ARGUMENT);
  231. mysqlToSqlState.put(new Integer(1071), SQL_STATE_ILLEGAL_ARGUMENT);
  232. mysqlToSqlState.put(new Integer(1072), SQL_STATE_ILLEGAL_ARGUMENT);
  233. mysqlToSqlState.put(new Integer(1073), SQL_STATE_ILLEGAL_ARGUMENT);
  234. mysqlToSqlState.put(new Integer(1074), SQL_STATE_ILLEGAL_ARGUMENT);
  235. mysqlToSqlState.put(new Integer(1075), SQL_STATE_ILLEGAL_ARGUMENT);
  236. mysqlToSqlState.put(new Integer(1082), SQL_STATE_ILLEGAL_ARGUMENT);
  237. mysqlToSqlState.put(new Integer(1083), SQL_STATE_ILLEGAL_ARGUMENT);
  238. mysqlToSqlState.put(new Integer(1084), SQL_STATE_ILLEGAL_ARGUMENT);
  239. //
  240. // ER_WRONG_VALUE_COUNT 1058
  241. //
  242. mysqlToSqlState.put(new Integer(1058),
  243. SQL_STATE_INSERT_VALUE_LIST_NO_MATCH_COL_LIST);
  244. // ER_CANT_CREATE_DB 1006
  245. // ER_DB_CREATE_EXISTS 1007
  246. // ER_DB_DROP_EXISTS 1008
  247. // ER_DB_DROP_DELETE 1009
  248. // ER_DB_DROP_RMDIR 1010
  249. // ER_CANT_DELETE_FILE 1011
  250. // ER_CANT_FIND_SYSTEM_REC 1012
  251. // ER_CANT_GET_STAT 1013
  252. // ER_CANT_GET_WD 1014
  253. // ER_UNEXPECTED_EOF 1039
  254. // ER_CANT_OPEN_FILE 1016
  255. // ER_FILE_NOT_FOUND 1017
  256. // ER_CANT_READ_DIR 1018
  257. // ER_CANT_SET_WD 1019
  258. // ER_CHECKREAD 1020
  259. // ER_DUP_KEY 1022
  260. // ER_ERROR_ON_CLOSE 1023
  261. // ER_ERROR_ON_READ 1024
  262. // ER_ERROR_ON_RENAME 1025
  263. // ER_ERROR_ON_WRITE 1026
  264. // ER_FILE_USED 1027
  265. // ER_FILSORT_ABORT 1028
  266. // ER_FORM_NOT_FOUND 1029
  267. // ER_GET_ERRNO 1030
  268. // ER_ILLEGAL_HA 1031
  269. // ER_KEY_NOT_FOUND 1032
  270. // ER_NOT_FORM_FILE 1033
  271. // ER_DBACCESS_DENIED_ERROR 1044
  272. // ER_NO_DB_ERROR 1046
  273. // ER_BAD_NULL_ERROR 1048
  274. // ER_BAD_DB_ERROR 1049
  275. // ER_TABLE_EXISTS_ERROR 1050
  276. // ER_BAD_TABLE_ERROR 1051
  277. mysqlToSqlState.put(new Integer(1051),
  278. SQL_STATE_BASE_TABLE_OR_VIEW_NOT_FOUND);
  279. // ER_NON_UNIQ_ERROR 1052
  280. // ER_BAD_FIELD_ERROR 1054
  281. mysqlToSqlState.put(new Integer(1054), SQL_STATE_COLUMN_NOT_FOUND);
  282. // ER_TEXTFILE_NOT_READABLE 1085
  283. // ER_FILE_EXISTS_ERROR 1086
  284. // ER_LOAD_INFO 1087
  285. // ER_ALTER_INFO 1088
  286. // ER_WRONG_SUB_KEY 1089
  287. // ER_CANT_REMOVE_ALL_FIELDS 1090
  288. // ER_CANT_DROP_FIELD_OR_KEY 1091
  289. // ER_INSERT_INFO 1092
  290. // ER_INSERT_TABLE_USED 1093
  291. // ER_LOCK_DEADLOCK 1213
  292. mysqlToSqlState.put(new Integer(1205), SQL_STATE_DEADLOCK);
  293. mysqlToSqlState.put(new Integer(1213), SQL_STATE_DEADLOCK);
  294. // ER_DUP_UNIQUE 1169
  295. // ER_NO_ROW_IS_REFERENCED 1216
  296. // ER_ROW_IS_REFERENCED 1217
  297. //
  298. mysqlToSqlState.put(new Integer(1169), SQL_STATE_INTEGRITY_CONSTRAINT_VIOLATION);
  299. mysqlToSqlState.put(new Integer(1216), SQL_STATE_INTEGRITY_CONSTRAINT_VIOLATION);
  300. mysqlToSqlState.put(new Integer(1217), SQL_STATE_INTEGRITY_CONSTRAINT_VIOLATION);
  301. mysqlToSql99State = new Hashtable();
  302. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_DUP_KEY), "23000");
  303. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_OUTOFMEMORY),
  304. "HY001");
  305. mysqlToSql99State.put(new Integer(
  306. MysqlErrorNumbers.ER_OUT_OF_SORTMEMORY), "HY001");
  307. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_CON_COUNT_ERROR),
  308. "08004");
  309. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_BAD_HOST_ERROR),
  310. "08S01");
  311. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_HANDSHAKE_ERROR),
  312. "08S01");
  313. mysqlToSql99State.put(new Integer(
  314. MysqlErrorNumbers.ER_DBACCESS_DENIED_ERROR), "42000");
  315. mysqlToSql99State.put(new Integer(
  316. MysqlErrorNumbers.ER_ACCESS_DENIED_ERROR), "28000");
  317. mysqlToSql99State.put(new Integer(
  318. MysqlErrorNumbers.ER_TABLE_EXISTS_ERROR), "42S01");
  319. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_BAD_TABLE_ERROR),
  320. "42S02");
  321. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_NON_UNIQ_ERROR),
  322. "23000");
  323. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_SERVER_SHUTDOWN),
  324. "08S01");
  325. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_BAD_FIELD_ERROR),
  326. "42S22");
  327. mysqlToSql99State.put(new Integer(
  328. MysqlErrorNumbers.ER_WRONG_FIELD_WITH_GROUP), "42000");
  329. mysqlToSql99State.put(new Integer(
  330. MysqlErrorNumbers.ER_WRONG_GROUP_FIELD), "42000");
  331. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_WRONG_SUM_SELECT),
  332. "42000");
  333. mysqlToSql99State.put(new Integer(
  334. MysqlErrorNumbers.ER_WRONG_VALUE_COUNT), "21S01");
  335. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_TOO_LONG_IDENT),
  336. "42000");
  337. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_DUP_FIELDNAME),
  338. "42S21");
  339. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_DUP_KEYNAME),
  340. "42000");
  341. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_DUP_ENTRY),
  342. "23000");
  343. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_WRONG_FIELD_SPEC),
  344. "42000");
  345. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_PARSE_ERROR),
  346. "42000");
  347. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_EMPTY_QUERY),
  348. "42000");
  349. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_NONUNIQ_TABLE),
  350. "42000");
  351. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_INVALID_DEFAULT),
  352. "42000");
  353. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_MULTIPLE_PRI_KEY),
  354. "42000");
  355. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_TOO_MANY_KEYS),
  356. "42000");
  357. mysqlToSql99State.put(new Integer(
  358. MysqlErrorNumbers.ER_TOO_MANY_KEY_PARTS), "42000");
  359. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_TOO_LONG_KEY),
  360. "42000");
  361. mysqlToSql99State.put(new Integer(
  362. MysqlErrorNumbers.ER_KEY_COLUMN_DOES_NOT_EXITS), "42000");
  363. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_BLOB_USED_AS_KEY),
  364. "42000");
  365. mysqlToSql99State.put(new Integer(
  366. MysqlErrorNumbers.ER_TOO_BIG_FIELDLENGTH), "42000");
  367. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_WRONG_AUTO_KEY),
  368. "42000");
  369. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_FORCING_CLOSE),
  370. "08S01");
  371. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_IPSOCK_ERROR),
  372. "08S01");
  373. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_NO_SUCH_INDEX),
  374. "42S12");
  375. mysqlToSql99State.put(new Integer(
  376. MysqlErrorNumbers.ER_WRONG_FIELD_TERMINATORS), "42000");
  377. mysqlToSql99State.put(new Integer(
  378. MysqlErrorNumbers.ER_BLOBS_AND_NO_TERMINATED), "42000");
  379. mysqlToSql99State.put(new Integer(
  380. MysqlErrorNumbers.ER_CANT_REMOVE_ALL_FIELDS), "42000");
  381. mysqlToSql99State.put(new Integer(
  382. MysqlErrorNumbers.ER_CANT_DROP_FIELD_OR_KEY), "42000");
  383. mysqlToSql99State.put(new Integer(
  384. MysqlErrorNumbers.ER_BLOB_CANT_HAVE_DEFAULT), "42000");
  385. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_WRONG_DB_NAME),
  386. "42000");
  387. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_WRONG_TABLE_NAME),
  388. "42000");
  389. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_TOO_BIG_SELECT),
  390. "42000");
  391. mysqlToSql99State.put(new Integer(
  392. MysqlErrorNumbers.ER_UNKNOWN_PROCEDURE), "42000");
  393. mysqlToSql99State.put(new Integer(
  394. MysqlErrorNumbers.ER_WRONG_PARAMCOUNT_TO_PROCEDURE), "42000");
  395. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_UNKNOWN_TABLE),
  396. "42S02");
  397. mysqlToSql99State.put(new Integer(
  398. MysqlErrorNumbers.ER_FIELD_SPECIFIED_TWICE), "42000");
  399. mysqlToSql99State.put(new Integer(
  400. MysqlErrorNumbers.ER_UNSUPPORTED_EXTENSION), "42000");
  401. mysqlToSql99State.put(new Integer(
  402. MysqlErrorNumbers.ER_TABLE_MUST_HAVE_COLUMNS), "42000");
  403. mysqlToSql99State.put(new Integer(
  404. MysqlErrorNumbers.ER_UNKNOWN_CHARACTER_SET), "42000");
  405. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_TOO_BIG_ROWSIZE),
  406. "42000");
  407. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_WRONG_OUTER_JOIN),
  408. "42000");
  409. mysqlToSql99State.put(new Integer(
  410. MysqlErrorNumbers.ER_NULL_COLUMN_IN_INDEX), "42000");
  411. mysqlToSql99State.put(new Integer(
  412. MysqlErrorNumbers.ER_PASSWORD_ANONYMOUS_USER), "42000");
  413. mysqlToSql99State.put(new Integer(
  414. MysqlErrorNumbers.ER_PASSWORD_NOT_ALLOWED), "42000");
  415. mysqlToSql99State.put(new Integer(
  416. MysqlErrorNumbers.ER_PASSWORD_NO_MATCH), "42000");
  417. mysqlToSql99State.put(new Integer(
  418. MysqlErrorNumbers.ER_WRONG_VALUE_COUNT_ON_ROW), "21S01");
  419. mysqlToSql99State.put(new Integer(
  420. MysqlErrorNumbers.ER_INVALID_USE_OF_NULL), "42000");
  421. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_REGEXP_ERROR),
  422. "42000");
  423. mysqlToSql99State.put(new Integer(
  424. MysqlErrorNumbers.ER_MIX_OF_GROUP_FUNC_AND_FIELDS), "42000");
  425. mysqlToSql99State.put(new Integer(
  426. MysqlErrorNumbers.ER_NONEXISTING_GRANT), "42000");
  427. mysqlToSql99State.put(new Integer(
  428. MysqlErrorNumbers.ER_TABLEACCESS_DENIED_ERROR), "42000");
  429. mysqlToSql99State.put(new Integer(
  430. MysqlErrorNumbers.ER_COLUMNACCESS_DENIED_ERROR), "42000");
  431. mysqlToSql99State.put(new Integer(
  432. MysqlErrorNumbers.ER_ILLEGAL_GRANT_FOR_TABLE), "42000");
  433. mysqlToSql99State.put(new Integer(
  434. MysqlErrorNumbers.ER_GRANT_WRONG_HOST_OR_USER), "42000");
  435. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_NO_SUCH_TABLE),
  436. "42S02");
  437. mysqlToSql99State.put(new Integer(
  438. MysqlErrorNumbers.ER_NONEXISTING_TABLE_GRANT), "42000");
  439. mysqlToSql99State.put(new Integer(
  440. MysqlErrorNumbers.ER_NOT_ALLOWED_COMMAND), "42000");
  441. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_SYNTAX_ERROR),
  442. "42000");
  443. mysqlToSql99State.put(new Integer(
  444. MysqlErrorNumbers.ER_ABORTING_CONNECTION), "08S01");
  445. mysqlToSql99State.put(new Integer(
  446. MysqlErrorNumbers.ER_NET_PACKET_TOO_LARGE), "08S01");
  447. mysqlToSql99State.put(new Integer(
  448. MysqlErrorNumbers.ER_NET_READ_ERROR_FROM_PIPE), "08S01");
  449. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_NET_FCNTL_ERROR),
  450. "08S01");
  451. mysqlToSql99State.put(new Integer(
  452. MysqlErrorNumbers.ER_NET_PACKETS_OUT_OF_ORDER), "08S01");
  453. mysqlToSql99State.put(new Integer(
  454. MysqlErrorNumbers.ER_NET_UNCOMPRESS_ERROR), "08S01");
  455. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_NET_READ_ERROR),
  456. "08S01");
  457. mysqlToSql99State.put(new Integer(
  458. MysqlErrorNumbers.ER_NET_READ_INTERRUPTED), "08S01");
  459. mysqlToSql99State.put(new Integer(
  460. MysqlErrorNumbers.ER_NET_ERROR_ON_WRITE), "08S01");
  461. mysqlToSql99State.put(new Integer(
  462. MysqlErrorNumbers.ER_NET_WRITE_INTERRUPTED), "08S01");
  463. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_TOO_LONG_STRING),
  464. "42000");
  465. mysqlToSql99State.put(new Integer(
  466. MysqlErrorNumbers.ER_TABLE_CANT_HANDLE_BLOB), "42000");
  467. mysqlToSql99State.put(new Integer(
  468. MysqlErrorNumbers.ER_TABLE_CANT_HANDLE_AUTO_INCREMENT), "42000");
  469. mysqlToSql99State.put(new Integer(
  470. MysqlErrorNumbers.ER_WRONG_COLUMN_NAME), "42000");
  471. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_WRONG_KEY_COLUMN),
  472. "42000");
  473. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_DUP_UNIQUE),
  474. "23000");
  475. mysqlToSql99State.put(new Integer(
  476. MysqlErrorNumbers.ER_BLOB_KEY_WITHOUT_LENGTH), "42000");
  477. mysqlToSql99State.put(new Integer(
  478. MysqlErrorNumbers.ER_PRIMARY_CANT_HAVE_NULL), "42000");
  479. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_TOO_MANY_ROWS),
  480. "42000");
  481. mysqlToSql99State.put(new Integer(
  482. MysqlErrorNumbers.ER_REQUIRES_PRIMARY_KEY), "42000");
  483. mysqlToSql99State.put(new Integer(
  484. MysqlErrorNumbers.ER_CHECK_NO_SUCH_TABLE), "42000");
  485. mysqlToSql99State.put(new Integer(
  486. MysqlErrorNumbers.ER_CHECK_NOT_IMPLEMENTED), "42000");
  487. mysqlToSql99State.put(new Integer(
  488. MysqlErrorNumbers.ER_CANT_DO_THIS_DURING_AN_TRANSACTION),
  489. "25000");
  490. mysqlToSql99State.put(new Integer(
  491. MysqlErrorNumbers.ER_NEW_ABORTING_CONNECTION), "08S01");
  492. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_MASTER_NET_READ),
  493. "08S01");
  494. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_MASTER_NET_WRITE),
  495. "08S01");
  496. mysqlToSql99State.put(new Integer(
  497. MysqlErrorNumbers.ER_TOO_MANY_USER_CONNECTIONS), "42000");
  498. mysqlToSql99State.put(new Integer(
  499. MysqlErrorNumbers.ER_READ_ONLY_TRANSACTION), "25000");
  500. mysqlToSql99State.put(new Integer(
  501. MysqlErrorNumbers.ER_NO_PERMISSION_TO_CREATE_USER), "42000");
  502. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_LOCK_DEADLOCK),
  503. "40001");
  504. mysqlToSql99State.put(new Integer(
  505. MysqlErrorNumbers.ER_NO_REFERENCED_ROW), "23000");
  506. mysqlToSql99State.put(new Integer(
  507. MysqlErrorNumbers.ER_ROW_IS_REFERENCED), "23000");
  508. mysqlToSql99State.put(new Integer(
  509. MysqlErrorNumbers.ER_CONNECT_TO_MASTER), "08S01");
  510. mysqlToSql99State.put(new Integer(
  511. MysqlErrorNumbers.ER_WRONG_NUMBER_OF_COLUMNS_IN_SELECT), "21000");
  512. mysqlToSql99State.put(new Integer(
  513. MysqlErrorNumbers.ER_USER_LIMIT_REACHED), "42000");
  514. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_NO_DEFAULT),
  515. "42000");
  516. mysqlToSql99State.put(new Integer(
  517. MysqlErrorNumbers.ER_WRONG_VALUE_FOR_VAR), "42000");
  518. mysqlToSql99State.put(new Integer(
  519. MysqlErrorNumbers.ER_WRONG_TYPE_FOR_VAR), "42000");
  520. mysqlToSql99State.put(new Integer(
  521. MysqlErrorNumbers.ER_CANT_USE_OPTION_HERE), "42000");
  522. mysqlToSql99State.put(new Integer(
  523. MysqlErrorNumbers.ER_NOT_SUPPORTED_YET), "42000");
  524. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_WRONG_FK_DEF),
  525. "42000");
  526. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_OPERAND_COLUMNS),
  527. "21000");
  528. mysqlToSql99State.put(new Integer(
  529. MysqlErrorNumbers.ER_SUBQUERY_NO_1_ROW), "21000");
  530. mysqlToSql99State.put(new Integer(
  531. MysqlErrorNumbers.ER_ILLEGAL_REFERENCE), "42S22");
  532. mysqlToSql99State.put(new Integer(
  533. MysqlErrorNumbers.ER_DERIVED_MUST_HAVE_ALIAS), "42000");
  534. mysqlToSql99State.put(new Integer(MysqlErrorNumbers.ER_SELECT_REDUCED),
  535. "01000");
  536. mysqlToSql99State.put(new Integer(
  537. MysqlErrorNumbers.ER_TABLENAME_NOT_ALLOWED_HERE), "42000");
  538. mysqlToSql99State.put(new Integer(
  539. MysqlErrorNumbers.ER_NOT_SUPPORTED_AUTH_MODE), "08004");
  540. mysqlToSql99State.put(new Integer(
  541. MysqlErrorNumbers.ER_SPATIAL_CANT_HAVE_NULL), "42000");
  542. mysqlToSql99State.put(new Integer(
  543. MysqlErrorNumbers.ER_COLLATION_CHARSET_MISMATCH), "42000");
  544. mysqlToSql99State.put(new Integer(
  545. MysqlErrorNumbers.ER_WARN_TOO_FEW_RECORDS), "01000");
  546. mysqlToSql99State.put(new Integer(
  547. MysqlErrorNumbers.ER_WARN_TOO_MANY_RECORDS), "01000");
  548. mysqlToSql99State.put(new Integer(
  549. MysqlErrorNumbers.ER_WARN_NULL_TO_NOTNULL), "01000");
  550. mysqlToSql99State.put(new Integer(
  551. MysqlErrorNumbers.ER_WARN_DATA_OUT_OF_RANGE), "01000");
  552. mysqlToSql99State.put(new Integer(
  553. MysqlErrorNumbers.ER_WARN_DATA_TRUNCATED), "01000");
  554. mysqlToSql99State.put(new Integer(
  555. MysqlErrorNumbers.ER_WRONG_NAME_FOR_INDEX), "42000");
  556. mysqlToSql99State.put(new Integer(
  557. MysqlErrorNumbers.ER_WRONG_NAME_FOR_CATALOG), "42000");
  558. mysqlToSql99State.put(new Integer(
  559. MysqlErrorNumbers.ER_UNKNOWN_STORAGE_ENGINE), "42000");
  560. }
  561. static String get(String stateCode) {
  562. return (String) sqlStateMessages.get(stateCode);
  563. }
  564. /**
  565. * Map MySQL error codes to X/Open or SQL-92 error codes
  566. *
  567. * @param errno the MySQL error code
  568. *
  569. * @return the corresponding X/Open or SQL-92 error code
  570. */
  571. static String mysqlToSqlState(int errno, boolean useSql92States) {
  572. if (useSql92States) {
  573. return mysqlToSql99(errno);
  574. }
  575. return mysqlToXOpen(errno);
  576. }
  577. private static String mysqlToXOpen(int errno) {
  578. Integer err = new Integer(errno);
  579. if (mysqlToSqlState.containsKey(err)) {
  580. return (String) mysqlToSqlState.get(err);
  581. }
  582. return SQL_STATE_GENERAL_ERROR;
  583. }
  584. private static String mysqlToSql99(int errno) {
  585. Integer err = new Integer(errno);
  586. if (mysqlToSql99State.containsKey(err)) {
  587. return (String) mysqlToSql99State.get(err);
  588. }
  589. return "HY000";
  590. }
  591. }