⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 t0006.c

📁 unix上的TDS协议实现
💻 C
字号:
/* FreeTDS - Library of routines accessing Sybase and Microsoft databases * Copyright (C) 1998-1999  Brian Bruns * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */#include <stdio.h>#include <tds.h>static char  software_version[]   = "$Id: t0006.c,v 1.3 2002/08/29 09:54:54 freddy77 Exp $";static void *no_unused_var_warn[] = {software_version, no_unused_var_warn};int run_query(TDSSOCKET *tds, char *query);int main(){   TDSLOGIN *login;   TDSSOCKET *tds;   int verbose = 0;   int rc;   int row_count, i;   /* variables for conversions */   TDSCOLINFO *curcol;   TDSRESULTINFO *resinfo;   char *src;   char dest[64];   TDS_INT srctype, srclen, destlen;   int src_id;   double src_val;   double src_err;   double tolerance = 0.000001;   char sql[256];   int num_sybreal = 5;   float sybreal[5];   int num_sybflt8 = 7;   double sybflt8[7];   sybreal[0] = 1.1;   sybreal[1] = 12345678;   sybreal[2] = 0.012345678;   sybreal[3] = 1.234567890e+20;   sybreal[4] = 1.234567890e-20;   sybflt8[0] = 1.1;   sybflt8[1] = 1234567890123456;   sybflt8[2] = 0.01234567890123456;   sybflt8[3] = 1.234567890123456e+20;   sybflt8[4] = 1.234567890123456e-20;   sybflt8[5] = 1.234567890123456e+200;   sybflt8[6] = 1.234567890123456e-200;   printf("%s: Test SYBREAL, SYBFLT8 values\n", __FILE__);   rc = try_tds_login(&login, &tds, __FILE__, verbose);   if (rc != TDS_SUCCEED) {      fprintf(stderr, "try_tds_login() failed\n");      return 1;   }   /**     ** SYBREAL tests    **/   if (verbose)  printf("Starting SYBREAL tests\n");   rc = run_query(tds, "DROP TABLE #test_table");   if (rc != TDS_SUCCEED) { return 1; }   rc = run_query(tds, "CREATE TABLE #test_table (id int, val real)");   if (rc != TDS_SUCCEED) { return 1; }   for (i=0; i<num_sybreal; i++) {     sprintf(sql, "INSERT #test_table (id, val) VALUES (%d, %.8g)", i, sybreal[i]);     if (verbose)  printf("%s\n", sql);     rc = run_query(tds, sql);     if (rc != TDS_SUCCEED) { return 1; }   }   rc = tds_submit_query(tds, "SELECT * FROM #test_table");   row_count = 0;   while ((rc=tds_process_result_tokens(tds))==TDS_SUCCEED) {      while ((rc=tds_process_row_tokens(tds))==TDS_SUCCEED) {         resinfo = tds->res_info;         for (i=0; i<resinfo->num_cols; i++) {            curcol = resinfo->columns[i];            src = &(resinfo->current_row[curcol->column_offset]);            if (verbose) {               srctype = curcol->column_type;               srclen = curcol->column_size;               tds_convert(srctype, src, srclen, SYBCHAR, dest, 64);               printf("col %i is %s\n", i, dest);            }            if (i==0) {               src_id = *(int *)src;            } else {               src_val = *(float *)src;               src_err = src_val - sybreal[src_id];               if (src_err != 0.0) {                  src_err = src_err/src_val;               }               if (src_err < -tolerance || src_err > tolerance) {                 fprintf(stderr, "SYBREAL expected %.8g  got %.8g\n",                    sybreal[src_id], src_val);                 fprintf(stderr, "Error was %.4g%%\n", 100*src_err);                 return 1;               }            }         }         row_count++;      }      if (rc == TDS_FAIL) {         fprintf(stderr, "tds_process_row_tokens() returned TDS_FAIL\n");         return 1;      }      else if (rc != TDS_NO_MORE_ROWS) {         fprintf(stderr, "tds_process_row_tokens() unexpected return\n");         return 1;      }   }   if (rc == TDS_FAIL) {      fprintf(stderr, "tds_process_result_tokens() returned TDS_FAIL for SELECT\n");      return 1;   }   else if (rc != TDS_NO_MORE_RESULTS) {      fprintf(stderr, "tds_process_result_tokens() unexpected return\n");   }   /**     ** SYBFLT8 tests    **/   if (verbose)  printf("Starting SYBFLT8 tests\n");   rc = run_query(tds, "DROP TABLE #test_table");   if (rc != TDS_SUCCEED) { return 1; }   rc = run_query(tds, "CREATE TABLE #test_table (id int, val float(48))");   if (rc != TDS_SUCCEED) { return 1; }   for (i=0; i<num_sybflt8; i++) {      sprintf(sql, "INSERT #test_table (id, val) VALUES (%d, %.15g)", i, sybflt8[i]);      if (verbose)  printf("%s\n", sql);      rc = run_query(tds, sql);      if (rc != TDS_SUCCEED) { return 1; }   }   rc = tds_submit_query(tds, "SELECT * FROM #test_table");   while ((rc=tds_process_result_tokens(tds))==TDS_SUCCEED) {      while ((rc=tds_process_row_tokens(tds))==TDS_SUCCEED) {         resinfo = tds->res_info;         for (i=0; i<resinfo->num_cols; i++) {            curcol = resinfo->columns[i];            src = &(resinfo->current_row[curcol->column_offset]);            if (verbose) {               srctype = curcol->column_type;               srclen = curcol->column_size;               tds_convert(srctype, src, srclen, SYBCHAR, dest, 64);               printf("col %i is %s\n", i, dest);            }            if (i==0) {               src_id = *(int *)src;            } else {               memcpy(&src_val, src, 8);               src_err = src_val - sybflt8[src_id];               if (src_err != 0.0){                  src_err = src_err/src_val;               }               if (src_err < -tolerance || src_err > tolerance) {                 fprintf(stderr, "SYBFLT8 expected %.16g  got %.16g\n",                    sybflt8[src_id], src_val);                 fprintf(stderr, "Error was %.4g%%\n", 100*src_err);                 return 1;               }            }         }      }      if (rc == TDS_FAIL) {         fprintf(stderr, "tds_process_row_tokens() returned TDS_FAIL\n");         return 1;      }      else if (rc != TDS_NO_MORE_ROWS) {         fprintf(stderr, "tds_process_row_tokens() unexpected return\n");         return 1;      }   }   if (rc == TDS_FAIL) {      fprintf(stderr, "tds_process_result_tokens() returned TDS_FAIL for SELECT\n");      return 1;   }   else if (rc != TDS_NO_MORE_RESULTS) {      fprintf(stderr, "tds_process_result_tokens() unexpected return\n");   }   try_tds_logout(login, tds, verbose);   return 0;}/* Run query for which there should be no return results */int run_query(TDSSOCKET *tds, char *query){   int rc;   rc = tds_submit_query(tds, query);   if (rc != TDS_SUCCEED) {      fprintf(stderr, "tds_submit_query() failed for query '%s'\n", query);      return TDS_FAIL;   }   while ((rc=tds_process_result_tokens(tds))==TDS_SUCCEED) {      if (tds->res_info->rows_exist) {         fprintf(stderr, "Error:  query should not return results\n");         return TDS_FAIL;      }   }   if (rc == TDS_FAIL) {      /* probably okay - DROP TABLE might cause this */      /* fprintf(stderr, "tds_process_result_tokens() returned TDS_FAIL for '%s'\n", query); */   }   else if (rc != TDS_NO_MORE_RESULTS) {      fprintf(stderr, "tds_process_result_tokens() unexpected return\n");      return TDS_FAIL;   }  return TDS_SUCCEED;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -