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

📄 sqltest.c

📁 Tokyo Cabinet的Tokyo Cabinet 是一个DBM的实现。这里的数据库由一系列key-value对的记录构成。key和value都可以是任意长度的字节序列,既可以是二进制也可以是字符
💻 C
字号:
#include <stdio.h>#include <stdlib.h>#include <string.h>#include <unistd.h>#include <sqlite3.h>#undef TRUE#define TRUE           1                 /* boolean true */#undef FALSE#define FALSE          0                 /* boolean false */#define RECBUFSIZ      256               /* buffer for records *//* global variables */const char *progname;                    /* program name */int showprgr;                            /* whether to show progression *//* function prototypes */int main(int argc, char **argv);void usage(void);int runwrite(int argc, char **argv);int runread(int argc, char **argv);int runtblwrite(int argc, char **argv);int runtblread(int argc, char **argv);int myrand(void);int callback(void *opq, int argc, char **argv, char **colname);int dowrite(char *name, int rnum);int doread(char *name, int rnum);int dotblwrite(char *name, int rnum);int dotblread(char *name, int rnum);/* main routine */int main(int argc, char **argv){  int rv;  progname = argv[0];  showprgr = TRUE;  if(getenv("HIDEPRGR")) showprgr = FALSE;  if(argc < 2) usage();  rv = 0;  if(!strcmp(argv[1], "write")){    rv = runwrite(argc, argv);  } else if(!strcmp(argv[1], "read")){    rv = runread(argc, argv);  } else if(!strcmp(argv[1], "tblwrite")){    rv = runtblwrite(argc, argv);  } else if(!strcmp(argv[1], "tblread")){    rv = runtblread(argc, argv);  } else {    usage();  }  return rv;}/* print the usage and exit */void usage(void){  fprintf(stderr, "%s: test cases for SQLite\n", progname);  fprintf(stderr, "\n");  fprintf(stderr, "usage:\n");  fprintf(stderr, "  %s write name rnum\n", progname);  fprintf(stderr, "  %s read name rnum\n", progname);  fprintf(stderr, "  %s tblwrite name rnum\n", progname);  fprintf(stderr, "  %s tblread name rnum\n", progname);  fprintf(stderr, "\n");  exit(1);}/* parse arguments of write command */int runwrite(int argc, char **argv){  char *name, *rstr;  int i, rnum, rv;  name = NULL;  rstr = NULL;  rnum = 0;  for(i = 2; i < argc; i++){    if(!name && argv[i][0] == '-'){      usage();    } else if(!name){      name = argv[i];    } else if(!rstr){      rstr = argv[i];    } else {      usage();    }  }  if(!name || !rstr) usage();  rnum = atoi(rstr);  if(rnum < 1) usage();  rv = dowrite(name, rnum);  return rv;}/* parse arguments of read command */int runread(int argc, char **argv){  char *name, *rstr;  int i, rnum, rv;  name = NULL;  rstr = NULL;  rnum = 0;  for(i = 2; i < argc; i++){    if(!name && argv[i][0] == '-'){      usage();    } else if(!name){      name = argv[i];    } else if(!rstr){      rstr = argv[i];    } else {      usage();    }  }  if(!name || !rstr) usage();  rnum = atoi(rstr);  if(rnum < 1) usage();  rv = doread(name, rnum);  return rv;}/* parse arguments of tblwrite command */int runtblwrite(int argc, char **argv){  char *name, *rstr;  int i, rnum, rv;  name = NULL;  rstr = NULL;  rnum = 0;  for(i = 2; i < argc; i++){    if(!name && argv[i][0] == '-'){      usage();    } else if(!name){      name = argv[i];    } else if(!rstr){      rstr = argv[i];    } else {      usage();    }  }  if(!name || !rstr) usage();  rnum = atoi(rstr);  if(rnum < 1) usage();  rv = dotblwrite(name, rnum);  return rv;}/* parse arguments of tblread command */int runtblread(int argc, char **argv){  char *name, *rstr;  int i, rnum, rv;  name = NULL;  rstr = NULL;  rnum = 0;  for(i = 2; i < argc; i++){    if(!name && argv[i][0] == '-'){      usage();    } else if(!name){      name = argv[i];    } else if(!rstr){      rstr = argv[i];    } else {      usage();    }  }  if(!name || !rstr) usage();  rnum = atoi(rstr);  if(rnum < 1) usage();  rv = dotblread(name, rnum);  return rv;}/* pseudo random number generator */int myrand(void){  static int cnt = 0;  return (lrand48() + cnt++) & 0x7FFFFFFF;}/* call back function for select statement */int callback(void *opq, int argc, char **argv, char **colname){  return 0;}/* perform write command */int dowrite(char *name, int rnum){  sqlite3 *db;  char sql[RECBUFSIZ], *errmsg;  int i, err;  if(showprgr) printf("<Writing Test of Hash>\n  name=%s  rnum=%d\n\n", name, rnum);  /* open a database */  unlink(name);  if(sqlite3_open(name, &db) != 0){    fprintf(stderr, "sqlite3_open failed\n");    return 1;  }  sprintf(sql, "CREATE TABLE tbl ( key TEXT PRIMARY KEY, val TEXT );");  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  sprintf(sql, "PRAGMA cache_size = %d;", rnum);  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  sprintf(sql, "BEGIN TRANSACTION;");  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  err = FALSE;  /* loop for each record */  for(i = 1; i <= rnum; i++){    /* store a record */    sprintf(sql, "INSERT INTO tbl VALUES ( '%08d', '%08d' );", i, i);    if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){      fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);      sqlite3_free(errmsg);      err = TRUE;    }    /* print progression */    if(showprgr && rnum > 250 && i % (rnum / 250) == 0){      putchar('.');      fflush(stdout);      if(i == rnum || i % (rnum / 10) == 0){        printf(" (%08d)\n", i);        fflush(stdout);      }    }  }  /* close the database */  sprintf(sql, "END TRANSACTION;");  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  sqlite3_close(db);  if(showprgr && !err) printf("ok\n\n");  return err ? 1 : 0;}/* perform read command */int doread(char *name, int rnum){  sqlite3 *db;  char sql[RECBUFSIZ], *errmsg;  int i, err;  if(showprgr) printf("<Reading Test of Hash>\n  name=%s  rnum=%d\n\n", name, rnum);  /* open a database */  if(sqlite3_open(name, &db) != 0){    fprintf(stderr, "sqlite3_open failed\n");    return 1;  }  sprintf(sql, "PRAGMA cache_size = %d;", rnum);  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  err = FALSE;  /* loop for each record */  for(i = 1; i <= rnum; i++){    /* store a record */    sprintf(sql, "SELECT * FROM tbl WHERE key = '%08d';", i);    if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){      fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);      sqlite3_free(errmsg);      err = TRUE;    }    /* print progression */    if(showprgr && rnum > 250 && i % (rnum / 250) == 0){      putchar('.');      fflush(stdout);      if(i == rnum || i % (rnum / 10) == 0){        printf(" (%08d)\n", i);        fflush(stdout);      }    }  }  /* close the database */  sqlite3_close(db);  if(showprgr && !err) printf("ok\n\n");  return err ? 1 : 0;}/* perform tblwrite command */int dotblwrite(char *name, int rnum){  sqlite3 *db;  char sql[RECBUFSIZ], *errmsg;  int i, err;  if(showprgr) printf("<Writing Test of Table>\n  name=%s  rnum=%d\n\n", name, rnum);  /* open a database */  unlink(name);  if(sqlite3_open(name, &db) != 0){    fprintf(stderr, "sqlite3_open failed\n");    return 1;  }  sprintf(sql, "CREATE TABLE tbl ( key INTEGER PRIMARY KEY, s TEXT, n INTEGER,"          " t TEXT, f TEXT );");  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  sprintf(sql, "CREATE INDEX tbl_s ON tbl ( s );");  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  sprintf(sql, "CREATE INDEX tbl_n ON tbl ( n );");  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  sprintf(sql, "PRAGMA cache_size = %d;", rnum);  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  sprintf(sql, "BEGIN TRANSACTION;");  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  err = FALSE;  /* loop for each record */  for(i = 1; i <= rnum; i++){    /* store a record */    sprintf(sql, "INSERT INTO tbl VALUES ( %d, '%08d', %d, '%08d', '%08d' );",            i, i, myrand() % i, i, myrand() % rnum);    if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){      fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);      sqlite3_free(errmsg);    }    /* print progression */    if(showprgr && rnum > 250 && i % (rnum / 250) == 0){      putchar('.');      fflush(stdout);      if(i == rnum || i % (rnum / 10) == 0){        printf(" (%08d)\n", i);        fflush(stdout);      }    }  }  /* close the database */  sprintf(sql, "END TRANSACTION;");  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  sqlite3_close(db);  if(showprgr && !err) printf("ok\n\n");  return err ? 1 : 0;}/* perform tblread command */int dotblread(char *name, int rnum){  sqlite3 *db;  char sql[RECBUFSIZ], *errmsg;  int i, err;  if(showprgr) printf("<Reading Test of Table>\n  name=%s  rnum=%d\n\n", name, rnum);  /* open a database */  if(sqlite3_open(name, &db) != 0){    fprintf(stderr, "sqlite3_open failed\n");    return 1;  }  sprintf(sql, "PRAGMA cache_size = %d;", rnum);  if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){    fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);    sqlite3_free(errmsg);  }  err = FALSE;  /* loop for each record */  for(i = 1; i <= rnum; i++){    /* store a record */    sprintf(sql, "SELECT * FROM tbl WHERE key = '%08d';", i);    if(sqlite3_exec(db, sql, callback, 0, &errmsg) != SQLITE_OK){      fprintf(stderr, "sqlite3_exec failed: %s\n", errmsg);      sqlite3_free(errmsg);    }    /* print progression */    if(showprgr && rnum > 250 && i % (rnum / 250) == 0){      putchar('.');      fflush(stdout);      if(i == rnum || i % (rnum / 10) == 0){        printf(" (%08d)\n", i);        fflush(stdout);      }    }  }  /* close the database */  sqlite3_close(db);  if(showprgr && !err) printf("ok\n\n");  return err ? 1 : 0;}/* END OF FILE */

⌨️ 快捷键说明

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