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

MySQL数据库

开发平台:

Visual C++

  1. /* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult 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. /*
  14.   Extra functions we want to do with a database
  15.   - All flags, exept record-cache-flags, are set in all used databases
  16.     record-cache-flags are set in myrg_rrnd when we are changing database.
  17. */
  18. #include "myrg_def.h"
  19. int myrg_extra(MYRG_INFO *info,enum ha_extra_function function,
  20.        void *extra_arg)
  21. {
  22.   int error,save_error=0;
  23.   MYRG_TABLE *file;
  24.   DBUG_ENTER("myrg_extra");
  25.   DBUG_PRINT("info",("function: %d",(ulong) function));
  26.   if (function == HA_EXTRA_CACHE)
  27.   {
  28.     info->cache_in_use=1;
  29.     info->cache_size= (extra_arg ? *(ulong*) extra_arg :
  30.        my_default_record_cache_size);
  31.   }
  32.   else
  33.   {
  34.     if (function == HA_EXTRA_NO_CACHE || function == HA_EXTRA_RESET ||
  35. function == HA_EXTRA_PREPARE_FOR_UPDATE)
  36.       info->cache_in_use=0;
  37.     if (function == HA_EXTRA_RESET || function == HA_EXTRA_RESET_STATE)
  38.     {
  39.       info->current_table=0;
  40.       info->last_used_table=info->open_tables;
  41.     }
  42.     for (file=info->open_tables ; file != info->end_table ; file++)
  43.     {
  44.       if ((error=mi_extra(file->table, function, extra_arg)))
  45. save_error=error;
  46.     }
  47.   }
  48.   DBUG_RETURN(save_error);
  49. }
  50. void myrg_extrafunc(MYRG_INFO *info, invalidator_by_filename inv)
  51. {
  52.   MYRG_TABLE *file;
  53.   DBUG_ENTER("myrg_extrafunc");
  54.   for (file=info->open_tables ; file != info->end_table ; file++)
  55.     file->table->s->invalidator = inv;
  56.   DBUG_VOID_RETURN;
  57. }