?? t0006.c
字號(hào):
/* 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;}
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -