mi_rrnd.c
上传用户:tsgydb
上传日期:2007-04-14
资源大小:10674k
文件大小:2k
源码类别:

MySQL数据库

开发平台:

Visual C++

  1. /* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
  2.    
  3.    This program is free software; you can redistribute it and/or modify
  4.    it under the terms of the GNU General Public License as published by
  5.    the Free Software Foundation; either version 2 of the License, or
  6.    (at your option) any later version.
  7.    
  8.    This program is distributed in the hope that it will be useful,
  9.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  10.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  11.    GNU General Public License for more details.
  12.    
  13.    You should have received a copy of the GNU General Public License
  14.    along with this program; if not, write to the Free Software
  15.    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
  16. /* Read a record with random-access. The position to the record must
  17.    get by MI_INFO. The next record can be read with pos= MI_POS_ERROR */
  18. #include "myisamdef.h"
  19. /*
  20.    Read a row based on position.
  21.    If filepos= HA_OFFSET_ERROR then read next row
  22.    Return values
  23.    Returns one of following values:
  24.    0 = Ok.
  25.    HA_ERR_RECORD_DELETED = Record is deleted.
  26.    HA_ERR_END_OF_FILE = EOF.
  27. */
  28. int mi_rrnd(MI_INFO *info, byte *buf, register my_off_t filepos)
  29. {
  30.   my_bool skipp_deleted_blocks;
  31.   DBUG_ENTER("mi_rrnd");
  32.   skipp_deleted_blocks=0;
  33.   if (filepos == HA_OFFSET_ERROR)
  34.   {
  35.     skipp_deleted_blocks=1;
  36.     if (info->lastpos == HA_OFFSET_ERROR) /* First read ? */
  37.       filepos= info->s->pack.header_length; /* Read first record */
  38.     else
  39.       filepos= info->nextpos;
  40.   }
  41.   info->lastinx= -1; /* Can't forward or backward */
  42.   /* Init all but update-flag */
  43.   info->update&= (HA_STATE_CHANGED | HA_STATE_ROW_CHANGED);
  44.   if (info->opt_flag & WRITE_CACHE_USED && flush_io_cache(&info->rec_cache))
  45.     DBUG_RETURN(my_errno);
  46.   DBUG_RETURN ((*info->s->read_rnd)(info,buf,filepos,skipp_deleted_blocks));
  47. }