-
Notifications
You must be signed in to change notification settings - Fork 0
/
prepare.c
141 lines (116 loc) · 2.84 KB
/
prepare.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
#include <stdio.h>
#include <sqlite3.h>
int main()
{
sqlite3 *db;
int rc;
rc = sqlite3_open("./employees.db", &db);
if( rc != SQLITE_OK )
{
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
sqlite3_close(db);
return(1);
}
int cols;
sqlite3_stmt *stmt;
const char* tail = NULL;
const char* sql = "select * from emp;";
printf("sql = %s\n", sql);
rc = sqlite3_prepare_v2(db, sql, -1, &stmt, &tail);
printf("after sqlite3_prepare_v2() called, rc = %d, tail = |%s|, tail = %p, *tail = %d\n", rc, tail, tail, *tail);
if( rc != SQLITE_OK )
{
fprintf(stderr, "SQL error: %s\n", sqlite3_errmsg(db));
}
printf("name = %d\n", sqlite3_column_type(stmt, 0));
printf("name = %d\n", sqlite3_column_type(stmt, 1));
printf("name = %d\n", sqlite3_column_type(stmt, 2));
cols = sqlite3_column_count(stmt);
rc = sqlite3_step(stmt);
while(rc == SQLITE_ROW)
{
int i;
for (i = 0; i < cols; i++)
{
printf("%s ", sqlite3_column_text(stmt, i));
}
printf("\n");
rc = sqlite3_step(stmt);
}
printf(">>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>\n");
rc = sqlite3_step(stmt);
while(rc == SQLITE_ROW)
{
int i;
for (i = 0; i < cols; i++)
{
printf("%s ", sqlite3_column_text(stmt, i));
}
printf("\n");
rc = sqlite3_step(stmt);
}
sqlite3_finalize(stmt);
sqlite3_close(db);
return 0;
}
int main2()
{
sqlite3 *db;
int rc;
rc = sqlite3_open("./employees.db", &db);
if( rc != SQLITE_OK )
{
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
sqlite3_close(db);
return(1);
}
int cols;
sqlite3_stmt *stmt;
const char* tail = NULL;
//const char* sql = "create table emp(id, name);select * from emp;";
const char* sql = "select * from emp;select * from emp where name like 'm%';";
while (sqlite3_complete(sql))
{
printf("sql = %s\n", sql);
rc = sqlite3_prepare_v2(db, sql, -1, &stmt, &tail);
printf("after sqlite3_prepare_v2() called, rc = %d, tail = |%s|, tail = %p, *tail = %d\n", rc, tail, tail, *tail);
if( rc != SQLITE_OK )
{
fprintf(stderr, "SQL error: %s\n", sqlite3_errmsg(db));
}
cols = sqlite3_column_count(stmt);
rc = sqlite3_step(stmt);
while(rc == SQLITE_ROW)
{
int i;
for (i = 0; i < cols; i++)
{
printf("%s ", sqlite3_column_text(stmt, i));
}
printf("\n");
rc = sqlite3_step(stmt);
}
if (sql == tail)
{
printf("please check you sql!\n");
break;
}
else
{
sql = tail;
}
printf("\n\n");
}
sqlite3_finalize(stmt);
sqlite3_close(db);
return 0;
}
int main_()
{
printf("%d\n", sqlite3_complete("select * from emp;")); // output 1
printf("%d\n", sqlite3_complete(";")); // output 1
printf("%d\n", sqlite3_complete("fuck you;")); // output 1
printf("%d\n", sqlite3_complete("select * from emp")); // output 0
printf("%d\n", sqlite3_complete("select * from emp\0;")); // output 0
return 0;
}