~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to examples/simple_multi.cc

  • Committer: Mark Atwood
  • Date: 2011-11-30 07:06:47 UTC
  • mfrom: (2463.1.6 drizzle-include)
  • Revision ID: me@mark.atwood.name-20111130070647-ixp7oalp70hkbt6l
mergeĀ lp:~brianaker/drizzle/libdrizzle-2.0-not-install

Show diffs side-by-side

added added

removed removed

Lines of Context:
34
34
 *
35
35
 */
36
36
 
37
 
#include <stdio.h>
38
 
#include <string.h>
39
 
#include <stdlib.h>
 
37
#include <cstdio>
 
38
#include <cstring>
 
39
#include <cstdlib>
40
40
 
41
41
#include <libdrizzle-2.0/drizzle_client.h>
42
42
 
45
45
int main(int argc, char *argv[])
46
46
{
47
47
  const char *query= "SELECT table_schema,table_name FROM tables";
48
 
  drizzle_st drizzle;
49
 
  drizzle_con_st *con;
50
 
  drizzle_result_st *result;
51
 
  drizzle_query_st *ql;
52
 
  drizzle_return_t ret;
53
 
  drizzle_row_t row;
54
 
  int x;
55
 
 
56
 
  con= (drizzle_con_st*)malloc(sizeof(drizzle_con_st) * SIMPLE_MULTI_COUNT);
57
 
  result= (drizzle_result_st*)malloc(sizeof(drizzle_result_st) * SIMPLE_MULTI_COUNT);
58
 
  ql= (drizzle_query_st*)malloc(sizeof(drizzle_query_st) * SIMPLE_MULTI_COUNT);
59
 
 
60
 
  if (drizzle_create(&drizzle) == NULL)
 
48
  drizzle_st *drizzle;
 
49
 
 
50
  std::vector<drizzle_con_st *> cons;
 
51
  std::vector<drizzle_result_st *> result;
 
52
  std::vector<drizzle_query_st *> ql;
 
53
 
 
54
  if ((drizzle= drizzle_create()) == NULL)
61
55
  {
62
 
    printf("drizzle_create:NULL\n");
 
56
    fprintf(stderr, "drizzle_create:NULL\n");
63
57
    return 1;
64
58
  }
65
59
 
66
60
  /* Create SIMPLE_MULTI_COUNT connections and initialize query list. */
67
 
  for (x= 0; x < SIMPLE_MULTI_COUNT; x++)
 
61
  for (int x= 0; x < SIMPLE_MULTI_COUNT; x++)
68
62
  {
 
63
    drizzle_con_st *con;
69
64
    if (x == 0)
70
65
    {
71
 
      if (drizzle_con_create(&drizzle, &(con[0])) == NULL)
 
66
      if ((con= drizzle_con_create(drizzle)) == NULL)
72
67
      {
73
 
        printf("drizzle_con_create:%s\n", drizzle_error(&drizzle));
 
68
        printf("drizzle_con_create:%s\n", drizzle_error(drizzle));
74
69
        return 1;
75
70
      }
76
71
 
77
72
      if (argc == 2 && !strcmp(argv[1], "-m"))
78
 
        drizzle_con_add_options(&(con[0]), DRIZZLE_CON_MYSQL);
 
73
      {
 
74
        drizzle_con_add_options(con, DRIZZLE_CON_MYSQL);
 
75
      }
79
76
      else if (argc != 1)
80
77
      {
81
78
        printf("usage: %s [-m]\n", argv[0]);
82
79
        return 1;
83
80
      }
84
81
 
85
 
      drizzle_con_set_db(&(con[0]), "information_schema");
 
82
      drizzle_con_set_db(con, "information_schema");
 
83
      cons.push_back(con);
86
84
    }
87
85
    else
88
86
    {
89
 
      if (drizzle_con_clone(&drizzle, &(con[x]), &(con[0])) == NULL)
 
87
      if ((con= drizzle_con_clone(drizzle, cons[0])) == NULL)
90
88
      {
91
 
        printf("drizzle_con_clone:%s\n", drizzle_error(&drizzle));
 
89
        fprintf(stderr, "drizzle_con_clone:%s\n", drizzle_error(drizzle));
92
90
        return 1;
93
91
      }
94
92
    }
95
93
 
96
 
    if (drizzle_query_add(&drizzle, &(ql[x]), &(con[x]), &(result[x]), query,
97
 
                          strlen(query), DRIZZLE_QUERY_NONE, NULL) == NULL)
 
94
    cons.push_back(con);
 
95
    drizzle_result_st *res= drizzle_result_create(con);
 
96
    result.push_back(res);
 
97
 
 
98
    drizzle_query_st *exec_query;
 
99
    if ((exec_query= drizzle_query_add(drizzle, NULL, con, res, query, strlen(query), DRIZZLE_QUERY_NONE, NULL)) == NULL)
98
100
    {
99
 
      printf("drizzle_query_add:%s\n", drizzle_error(&drizzle));
 
101
      fprintf(stderr, "drizzle_query_add:%s\n", drizzle_error(drizzle));
100
102
      return 1;
101
103
    }
 
104
    ql.push_back(exec_query);
102
105
  }
103
106
 
104
 
  ret= drizzle_query_run_all(&drizzle);
 
107
  drizzle_return_t ret= drizzle_query_run_all(drizzle);
105
108
  if (ret != DRIZZLE_RETURN_OK)
106
109
  {
107
 
    printf("drizzle_query_run_all:%s\n", drizzle_error(&drizzle));
 
110
    printf("drizzle_query_run_all:%s\n", drizzle_error(drizzle));
108
111
    return 1;
109
112
  }
110
113
 
111
 
  for (x= 0; x < SIMPLE_MULTI_COUNT; x++)
 
114
  uint32_t x= 0;
 
115
  for (std::vector<drizzle_result_st *>::iterator iter= result.begin(); iter != result.end(); iter++)
112
116
  {
113
 
    if (drizzle_result_error_code(&(result[x])) != 0)
 
117
    if (drizzle_result_error_code(*iter) != 0)
114
118
    {
115
 
      printf("%d:%s\n", drizzle_result_error_code(&(result[x])),
116
 
             drizzle_result_error(&(result[x])));
 
119
      printf("%d:%s\n", drizzle_result_error_code(*iter),
 
120
             drizzle_result_error(*iter));
117
121
      continue;
118
122
    }
119
123
 
120
 
    while ((row= drizzle_row_next(&(result[x]))) != NULL)
121
 
      printf("%d %s:%s\n", x, row[0], row[1]);
 
124
    drizzle_row_t row;
 
125
    while ((row= drizzle_row_next(*iter)) != NULL)
 
126
    {
 
127
      printf("%x %s:%s\n", x, row[0], row[1]);
 
128
    }
 
129
    x++;
122
130
  }
123
131
 
124
 
  drizzle_free(&drizzle);
 
132
  drizzle_free(drizzle);
125
133
 
126
 
  free(con);
127
 
  free(result);
128
 
  free(ql);
129
134
  return 0;
130
135
}