#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sqlite3.h>
int insert_sql(sqlite3 *db);
int callback(void*para,int f_num,char**f_value,char**f_name);
int main(int argc, char *argv[])
{
if(2 > argc){
printf("Usage: %s <sqlite_name>\n", argv[0]); //判断输入新建数据库的名字
return -1;
}
// SQLITE_API int sqlite3_open(
// const char *filename, /* Database filename (UTF-8) */
// sqlite3 **ppDb /* OUT: SQLite db handle */
// );
// 函数说明:该程序会通过指定的文件名参数打开一个数据库文件
// 数据库的连接返回到*ppDb,函数的返回值代表了操作状态,例如成功
// 就返回SQLITE_OK,否则返回错误代码和意外情况下不能分配内存来的得到
// sqlite3就返回NULL
sqlite3 *db;
if(sqlite3_open(argv[1], &db) != SQLITE_OK){ //新建数据库
perror("sqlite3_open");
return -1;
}
char *err;
char *sql_create = "create table if not exists stu(id int, name char, sex char, score float)";
if(sqlite3_exec(db, sql_create, NULL, NULL, &err) != SQLITE_OK){
printf("errmsg:%s\n", err);
return -1;
}
insert_sql(db); //用户输入并创建一条记录
// SQLITE_API int sqlite3_exec(
// sqlite3*, /* An open database */
// const char *sql, /* SQL to be evaluated */
// int (*callback)(void*,int,char**,char**), /* Callback function */
// void *, /* 1st argument to callback */
// char **errmsg /* Error msg written here */
// );
// 函数说明:该函数为具体执行SQL语句的函数
// 参数1:打开的数据库连接对象
// 参数2:传入的SQL语句,以‘/0’结尾
// 参数3:是回调函数,如果传入参数不为NULL,则得到一个结果行就会调用该回调函数
// 参数4:自定义的一个指针,目的是传入到回调函数参数以供使用。
// 参数5:错误信息,如果语句执行失败,就可以查阅该指针,这里的参数是输出特性
// (即主调函数将类型变量的地址传入,函数分配内存赋值给该变量)
// 同时在执行完该函数后又不需要错误信息时,为了避免内存泄露,应该调用
// sqlite3_free()来释放这块内存
if(sqlite3_exec(db, "select * from stu", callback, "男", NULL) != SQLITE_OK){ //查询函数
perror("sqlite3_exec");
return -1;
}
// SQLITE_API int sqlite3_close(sqlite3*);
// 函数说明:前面如果用 sqlite3_open 开启了一个数据库,结尾时不要忘了用这个函数关闭数据库
// 同样返回值为操作状态
sqlite3_close(db);
}
int insert_sql(sqlite3 *db)
{
char sql[100] = {0};
int id;
char name[20], sex[10];
float s;
while(1){
printf("please input id name sex score: \n");
scanf("%d %s %s %f", &id, name, sex, &s);
if(-1 == id){
break;
}
sprintf(sql, "insert into stu values(%d,'%s', '%s', %0.2f)", id, name, sex, s); //将字符串写入sql
if(sqlite3_exec(db, sql, NULL, NULL, NULL) != SQLITE_OK){ //执行sql语句
perror("sqlite3_exec");
return -1;
}
}
}
int callback(void*para,int f_num,char**f_value,char**f_name)
{
static int flag = 0;
int i;
if(flag == 0){
printf("select: %s\n", (char *)para);
for(i = 0; i < f_num; i++){
printf("%-15s", f_name[i]);
}
puts("");
flag = 1;
}
for(i = 0; i < f_num; i++){
if(0 == strncasecmp((char *)para, f_value[2], 3)){
printf("%-15s", f_value[i]);
}
}
puts("");
return 0;
}