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

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. #ifndef DIHADDFRAG_HPP
  14. #define DIHADDFRAG_HPP
  15. #include <NodeBitmask.hpp>
  16. #include <ndb_limits.h>
  17. /**
  18.  * 
  19.  */
  20. class DihAddFragConf {
  21.   /**
  22.    * Sender(s) / Reciver(s)
  23.    */
  24.   friend class Dbdih;
  25.     
  26. public:
  27.   STATIC_CONST( SignalLength = 2 );
  28. private:  
  29.   Uint32 senderNodeId;
  30.   Uint32 tableId;
  31. };
  32. /**
  33.  * 
  34.  */
  35. class DihAddFragReq {
  36.   /**
  37.    * Sender(s) / Reciver(s)
  38.    */
  39.   friend class Dbdih;
  40.     
  41. public:
  42.   STATIC_CONST( SignalLength = 10 + MAX_REPLICAS );
  43. private:
  44.   Uint32 masterRef;
  45.   Uint32 tableId;
  46.   Uint32 fragId;
  47.   Uint32 kValue;
  48.   Uint32 method;
  49.   Uint32 mask;
  50.   Uint32 hashPointer;
  51.   Uint32 noOfFragments;
  52.   Uint32 noOfBackups;
  53.   Uint32 storedTable;
  54.   Uint32 nodes[MAX_REPLICAS];
  55. };
  56. #endif