SQLError.cpp
上传用户:romrleung
上传日期:2022-05-23
资源大小:18897k
文件大小:2k
源码类别:

MySQL数据库

开发平台:

Visual C++

  1. /* Copyright (C) 2003 MySQL AB
  2.    This program is free software; you can redistribute it and/or modify
  3.    it under the terms of the GNU General Public License as published by
  4.    the Free Software Foundation; either version 2 of the License, or
  5.    (at your option) any later version.
  6.    This program is distributed in the hope that it will be useful,
  7.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  8.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  9.    GNU General Public License for more details.
  10.    You should have received a copy of the GNU General Public License
  11.    along with this program; if not, write to the Free Software
  12.    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
  13. #include "driver.hpp"
  14. #if ODBCVER >= 0x0000
  15. SQLRETURN SQL_API
  16. SQLError(
  17.     SQLHENV EnvironmentHandle,
  18.     SQLHDBC ConnectionHandle,
  19.     SQLHSTMT StatementHandle,
  20.     SQLCHAR* Sqlstate,
  21.     SQLINTEGER* NativeError,
  22.     SQLCHAR* MessageText,
  23.     SQLSMALLINT BufferLength,
  24.     SQLSMALLINT* TextLength)
  25. {
  26.     driver_enter(SQL_API_SQLERROR);
  27.     const char* const sqlFunction = "SQLError";
  28.     HandleRoot* const pRoot = HandleRoot::instance();
  29.     HandleEnv* pEnv = pRoot->findEnv(EnvironmentHandle);
  30.     HandleDbc* pDbc = pRoot->findDbc(ConnectionHandle);
  31.     HandleStmt* pStmt = pRoot->findStmt(StatementHandle);
  32.     if (pStmt == 0 && pDbc == 0 && pEnv == 0) {
  33. driver_exit(SQL_API_SQLERROR);
  34. return SQL_INVALID_HANDLE;
  35.     }
  36.     Ctx ctx; // discard diagnostics
  37.     ctx.logSqlEnter(sqlFunction);
  38.     if (pStmt != 0) {
  39. try {
  40.     pStmt->sqlError(ctx, Sqlstate, NativeError, MessageText, BufferLength, TextLength);
  41. } catch (CtxAssert& ctxAssert) {
  42.     ctx.handleEx(ctxAssert);
  43. }
  44.     } else if (pDbc != 0) {
  45. try {
  46.     pDbc->sqlError(ctx, Sqlstate, NativeError, MessageText, BufferLength, TextLength);
  47. } catch (CtxAssert& ctxAssert) {
  48.     ctx.handleEx(ctxAssert);
  49. }
  50.     } else {
  51. try {
  52.     pEnv->sqlError(ctx, Sqlstate, NativeError, MessageText, BufferLength, TextLength);
  53. } catch (CtxAssert& ctxAssert) {
  54.     ctx.handleEx(ctxAssert);
  55. }
  56.     }
  57.     ctx.logSqlExit();
  58.     SQLRETURN ret = ctx.getCode();
  59.     driver_exit(SQL_API_SQLERROR);
  60.     return ret;
  61. }
  62. #endif // ODBCVER >= 0x0000