SQLForeignKeys.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. SQLForeignKeys(
  17.     SQLHSTMT hstmt,
  18.     SQLCHAR* szPkCatalogName,
  19.     SQLSMALLINT cbPkCatalogName,
  20.     SQLCHAR* szPkSchemaName,
  21.     SQLSMALLINT cbPkSchemaName,
  22.     SQLCHAR* szPkTableName,
  23.     SQLSMALLINT cbPkTableName,
  24.     SQLCHAR* szFkCatalogName,
  25.     SQLSMALLINT cbFkCatalogName,
  26.     SQLCHAR* szFkSchemaName,
  27.     SQLSMALLINT cbFkSchemaName,
  28.     SQLCHAR* szFkTableName,
  29.     SQLSMALLINT cbFkTableName)
  30. {
  31. #ifndef auto_SQLForeignKeys
  32.     const char* const sqlFunction = "SQLForeignKeys";
  33.     Ctx ctx;
  34.     ctx_log1(("*** not implemented: %s", sqlFunction));
  35.     return SQL_ERROR;
  36. #else
  37.     driver_enter(SQL_API_SQLFOREIGNKEYS);
  38.     const char* const sqlFunction = "SQLForeignKeys";
  39.     HandleRoot* const pRoot = HandleRoot::instance();
  40.     HandleStmt* pStmt = pRoot->findStmt(hstmt);
  41.     if (pStmt == 0) {
  42. driver_exit(SQL_API_SQLFOREIGNKEYS);
  43.         return SQL_INVALID_HANDLE;
  44.     }
  45.     Ctx& ctx = *new Ctx;
  46.     ctx.logSqlEnter(sqlFunction);
  47.     if (ctx.ok())
  48.         pStmt->sqlForeignKeys(
  49.             ctx,
  50.             &szPkCatalogName,
  51.             cbPkCatalogName,
  52.             &szPkSchemaName,
  53.             cbPkSchemaName,
  54.             &szPkTableName,
  55.             cbPkTableName,
  56.             &szFkCatalogName,
  57.             cbFkCatalogName,
  58.             &szFkSchemaName,
  59.             cbFkSchemaName,
  60.             &szFkTableName,
  61.             cbFkTableName
  62.         );
  63.     pStmt->saveCtx(ctx);
  64.     ctx.logSqlExit();
  65.     SQLRETURN ret = ctx.getCode();
  66.     driver_exit(SQL_API_SQLFOREIGNKEYS);
  67.     return ret;
  68. #endif
  69. }
  70. #endif // ODBCVER >= 0x0000