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

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 "HandleRoot.hpp"
  14. static void
  15. callback_SQL_ATTR_CONNECTION_POOLING_set(Ctx& ctx, HandleBase* self, const OdbcData& data)
  16. {
  17.     HandleRoot* pRoot = static_cast<HandleRoot*>(self);
  18.     ctx_assert(pRoot != 0 && data.type() == OdbcData::Uinteger);
  19.     SQLUINTEGER value = data.uinteger();
  20.     switch (value) {
  21.     case SQL_CP_OFF:
  22. break;
  23.     case SQL_CP_ONE_PER_DRIVER:
  24.     case SQL_CP_ONE_PER_HENV:
  25. ctx.pushStatus(Sqlstate::_HYC00, Error::Gen, "connection pooling not supported");
  26. break;
  27.     default:
  28. ctx.pushStatus(Sqlstate::_HY024, Error::Gen, "invalid connection pooling value %u", (unsigned)value);
  29. break;
  30.     }
  31. }
  32. static void
  33. callback_SQL_ATTR_CONNECTION_POOLING_default(Ctx& ctx, HandleBase* self, OdbcData& data)
  34. {
  35.     HandleRoot* pRoot = static_cast<HandleRoot*>(self);
  36.     ctx_assert(pRoot != 0);
  37.     SQLUINTEGER value = SQL_CP_OFF;
  38.     data.setValue(value);
  39. }
  40. static void
  41. callback_SQL_ATTR_CP_MATCH_set(Ctx& ctx, HandleBase* self, const OdbcData& data)
  42. {
  43.     HandleRoot* pRoot = static_cast<HandleRoot*>(self);
  44.     ctx_assert(pRoot != 0 && data.type() == OdbcData::Uinteger);
  45.     SQLUINTEGER value = data.uinteger();
  46.     switch (value) {
  47.     case SQL_CP_STRICT_MATCH:
  48. break;
  49.     case SQL_CP_RELAXED_MATCH:
  50. break;
  51.     default:
  52. ctx.pushStatus(Sqlstate::_HY024, Error::Gen, "invalid cp match value %u", (unsigned)value);
  53. break;
  54.     }
  55. }
  56. static void
  57. callback_SQL_ATTR_CP_MATCH_default(Ctx& ctx, HandleBase* self, OdbcData& data)
  58. {
  59.     HandleRoot* pRoot = static_cast<HandleRoot*>(self);
  60.     ctx_assert(pRoot != 0);
  61.     SQLUINTEGER value = SQL_CP_STRICT_MATCH;
  62.     data.setValue(value);
  63. }
  64. AttrSpec HandleRoot::m_attrSpec[] = {
  65.     {   SQL_ATTR_CONNECTION_POOLING,
  66.         OdbcData::Uinteger,
  67.         Attr_mode_readwrite,
  68.         callback_SQL_ATTR_CONNECTION_POOLING_set,
  69.         callback_SQL_ATTR_CONNECTION_POOLING_default,
  70.     },
  71.     {   SQL_ATTR_CP_MATCH,
  72.         OdbcData::Uinteger,
  73.         Attr_mode_readwrite,
  74.         callback_SQL_ATTR_CP_MATCH_set,
  75.         callback_SQL_ATTR_CP_MATCH_default,
  76.     },
  77.     {   0,
  78.         OdbcData::Undef,
  79.         Attr_mode_undef,
  80.         0,
  81.         0,
  82.     },
  83. };