myrg_rnext_same.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. #include "myrg_def.h"
  14. int myrg_rnext_same(MYRG_INFO *info, byte *buf)
  15. {
  16.   int err;
  17.   MI_INFO *mi;
  18.   if (!info->current_table)
  19.     return (HA_ERR_KEY_NOT_FOUND);
  20.   /* at first, do rnext for the table found before */
  21.   if ((err=mi_rnext_same(info->current_table->table,NULL)))
  22.   {
  23.     if (err == HA_ERR_END_OF_FILE)
  24.     {
  25.       queue_remove(&(info->by_key),0);
  26.       if (!info->by_key.elements)
  27.         return HA_ERR_END_OF_FILE;
  28.     }
  29.     else
  30.       return err;
  31.   }
  32.   else
  33.   {
  34.     /* Found here, adding to queue */
  35.     queue_top(&(info->by_key))=(byte *)(info->current_table);
  36.     queue_replaced(&(info->by_key));
  37.   }
  38.   /* now, mymerge's read_next is as simple as one queue_top */
  39.   mi=(info->current_table=(MYRG_TABLE *)queue_top(&(info->by_key)))->table;
  40.   return _myrg_mi_read_record(mi,buf);
  41. }