select_test.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 library is free software; you can redistribute it and/or
  4.    modify it under the terms of the GNU Library General Public
  5.    License as published by the Free Software Foundation; either
  6.    version 2 of the License, or (at your option) any later version.
  7.    
  8.    This library 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 GNU
  11.    Library General Public License for more details.
  12.    
  13.    You should have received a copy of the GNU Library General Public
  14.    License along with this library; if not, write to the Free
  15.    Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
  16.    MA 02111-1307, USA */
  17. #if defined(_WIN32) || defined(_WIN64)
  18. #include <windows.h>
  19. #endif
  20. #include <stdio.h>
  21. #include <stdlib.h>
  22. #include "mysql.h"
  23. #define SELECT_QUERY "select name from test where num = %d"
  24. int main(int argc, char **argv)
  25. {
  26.   int count, num;
  27.   MYSQL mysql,*sock;
  28.   MYSQL_RES *res;
  29.   char qbuf[160];
  30.   if (argc != 3)
  31.   {
  32.     fprintf(stderr,"usage : select_test <dbname> <num>nn");
  33.     exit(1);
  34.   }
  35.   mysql_init(&mysql);
  36.   if (!(sock = mysql_real_connect(&mysql,NULL,0,0,argv[1],0,NULL,0)))
  37.   {
  38.     fprintf(stderr,"Couldn't connect to engine!n%snn",mysql_error(&mysql));
  39.     perror("");
  40.     exit(1);
  41.   }
  42.   count = 0;
  43.   num = atoi(argv[2]);
  44.   while (count < num)
  45.   {
  46.     sprintf(qbuf,SELECT_QUERY,count);
  47.     if(mysql_query(sock,qbuf))
  48.     {
  49.       fprintf(stderr,"Query failed (%s)n",mysql_error(sock));
  50.       exit(1);
  51.     }
  52.     if (!(res=mysql_store_result(sock)))
  53.     {
  54.       fprintf(stderr,"Couldn't get result from %sn",
  55.       mysql_error(sock));
  56.       exit(1);
  57.     }
  58. #ifdef TEST
  59.     printf("number of fields: %dn",mysql_num_fields(res));
  60. #endif
  61.     mysql_free_result(res);
  62.     count++;
  63.   }
  64.   mysql_close(sock);
  65.   exit(0);
  66.   return 0; /* Keep some compilers happy */
  67. }