2
* Drizzle Client & Protocol Library
4
* Copyright (C) 2008 Eric Day (eday@oddments.org)
7
* Redistribution and use in source and binary forms, with or without
8
* modification, are permitted provided that the following conditions are
11
* * Redistributions of source code must retain the above copyright
12
* notice, this list of conditions and the following disclaimer.
14
* * Redistributions in binary form must reproduce the above
15
* copyright notice, this list of conditions and the following disclaimer
16
* in the documentation and/or other materials provided with the
19
* * The names of its contributors may not be used to endorse or
20
* promote products derived from this software without specific prior
23
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
26
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
27
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
28
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
29
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
30
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
31
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
33
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
46
#include <libdrizzle/drizzle_client.h>
48
#define BUFFER_CHUNK 8192
50
int main(int argc, char *argv[])
58
size_t buffer_size= 0;
59
size_t buffer_total= 0;
62
drizzle_con_st *con= (drizzle_con_st*)malloc(sizeof(drizzle_con_st));
63
drizzle_result_st result;
65
drizzle_field_t field;
72
printf("Failed to allocate memory for drizzle connection");
76
/* The docs say this might fail, so check for errors. */
77
if (drizzle_create(&drizzle) == NULL)
79
printf("drizzle_create:failed\n");
83
if (drizzle_con_create(&drizzle, con) == NULL)
85
printf("drizzle_con_create:%s\n", drizzle_error(&drizzle));
89
while ((c = getopt(argc, argv, "d:h:Hmp:P:u:")) != -1)
94
drizzle_con_set_db(con, optarg);
102
drizzle_con_add_options(con, DRIZZLE_CON_MYSQL);
110
port= (in_port_t)atoi(optarg);
119
printf("\nUsage: %s [options] [query]\n", argv[0]);
120
printf("\t-d <db> - Use <db> for the connection\n");
121
printf("\t-h <host> - Connect to <host>\n");
122
printf("\t-H - Print this help menu\n");
123
printf("\t-m - Use MySQL protocol\n");
124
printf("\t-p <password> - Use <password> for authentication\n");
125
printf("\t-P <port> - Connect to <port>\n");
126
printf("\t-u <user> - Use <user> for authentication\n");
131
drizzle_con_set_tcp(con, host, port);
132
drizzle_con_set_auth(con, user, password);
138
printf("read:%d\n", errno);
142
buffer_size+= (size_t)read_size;
144
buffer= realloc(buffer, buffer_size + BUFFER_CHUNK);
147
printf("realloc:%d\n", errno);
151
buffer_total= buffer_size + BUFFER_CHUNK;
152
} while ((read_size= read(0, buffer + buffer_size, BUFFER_CHUNK)) != 0);
154
(void)drizzle_query(con, &result, buffer, buffer_size, &ret);
155
if (ret != DRIZZLE_RETURN_OK)
157
printf("drizzle_query:%s\n", drizzle_error(&drizzle));
163
ret= drizzle_column_skip(&result);
164
if (ret != DRIZZLE_RETURN_OK)
166
printf("drizzle_column_skip:%s\n", drizzle_error(&drizzle));
170
while (drizzle_row_read(&result, &ret) != 0 && ret == DRIZZLE_RETURN_OK)
174
field= drizzle_field_read(&result, &offset, &size, &total, &ret);
175
if (ret == DRIZZLE_RETURN_ROW_END)
177
else if (ret != DRIZZLE_RETURN_OK)
179
printf("drizzle_field_read:%s\n", drizzle_error(&drizzle));
186
printf("%.*s", (int)size, field);
188
if (offset + size == total)
195
if (ret != DRIZZLE_RETURN_OK)
197
printf("drizzle_row_read:%s\n", drizzle_error(&drizzle));
201
drizzle_result_free(&result);
202
drizzle_con_free(con);
203
drizzle_free(&drizzle);