数据库--Sqlite3

1、思维导图

2sqlite3在linux中是实现数据的增删,改

#include<myhead.h>

int main(int argc, const char *argv[])

{

//1、定义一个数据库句柄指针

sqlite3* ppDb =NULL;

//2、创建或打开数据库

if(sqlite3_open("./mydb.db",&ppDb)!=SQLITE_OK)

{

printf("sqlite3_open error\n");

return -1;

}

printf("数据库成功打开\n");

//

//3、创建数据表

//3.1、准备sql语句

char sql[128]="create table if not exists student(student_id int ,name char,sex char ,score double);";

char *errmsg =NULL;

if(sqlite3_exec(ppDb,sql,NULL,NULL,&errmsg)!=SQLITE_OK)

{

printf("%s\n",errmsg);

return -1;

}

printf("数据表创建成功\n");

int a=0;

int a1=0;

char a2[20]="";

char a3[5]="";

int a4=0;

printf("*****学生信息***********\n");

printf("*****1、添加学生信息****\n");

printf("*****2、修改学生信息*****\n");

printf("*****3、删除学生信息*****\n");

printf("*****4、查找学生信息******\n");

printf("*****0、退出系统**********\n");

printf("请输入》》》:");

scanf("%d",&a);

switch(a)

{

case 1:

{

printf("请输入信息:");

scanf("%d %s %s %d",&a1,a2,a3,&a4);

getchar();

sprintf(sql,"insert into student values(%d,\"%s\",\"%s\",%d);",a1,a2,a3,a4);

if(sqlite3_exec(ppDb,sql,NULL,NULL,&errmsg)!=SQLITE_OK)

{

printf("%s\n",errmsg);

return -1;

}

break;

}

case 2:

{

printf("请输入学号和姓名:");

scanf("%d %s %s %d",a1,a2,a3,a4);

getchar();

sprintf(sql,"UPDATE TABLE student student_id=%d AND name=\"%s\" WHERE sex=\"%s\" %d;",a1,a2,a3,a4);

if(sqlite3_exec(ppDb,sql,NULL,NULL,&errmsg)!=SQLITE_OK)

{

printf("%s\n",errmsg);

return -1;

}

break;

}

case 3:

{

printf("请输入信息:");

scanf("%s",a2);

getchar();

sprintf(sql,"DELETE FROM student WHERE name=\"%s\"",a2);

if(sqlite3_exec(ppDb,sql,NULL,NULL,&errmsg)!=SQLITE_OK)

{

printf("%s\n",errmsg);

return -1;

}

break;

}

case 0:

{

sprintf(sql,"DROP TABLE student;");

if(sqlite3_exec(ppDb,sql,NULL,NULL,&errmsg)!=SQLITE_OK)

{

printf("%s\n",errmsg);

return -1;

}

break;

}

}

sqlite3_close(ppDb);

return 0;

}

相关推荐
wuqingshun3141594 小时前
如何停止一个正在退出的线程
java·开发语言·jvm
AMoon丶8 小时前
C++模版-函数模版,类模版基础
java·linux·c语言·开发语言·jvm·c++·算法
Coder_Boy_10 小时前
分布式系统核心技术完整梳理(含分库分表、分布式事务、熔断补偿)
jvm·分布式·spring·中间件
wuqingshun31415915 小时前
说说java中实现多线程有几种方法
java·开发语言·jvm
light blue bird16 小时前
MES/ERP报表大致化元素组排类查询
jvm·数据库·.net·ai大数据
ldj202016 小时前
Arthas常用方式
jvm·arthas
星辰_mya17 小时前
分布式锁:跨 JVM 的“工商局备案章”
jvm·分布式·面试
星辰_mya18 小时前
线上故障排查实战经验总结一
java·开发语言·jvm·面试
填满你的记忆18 小时前
JVM 内存模型详解:Java 程序到底是如何运行的?
java·开发语言·jvm
Coder_Boy_19 小时前
分布式系统“三高”与数据一致性核心实践(基于实操梳理)
java·jvm·spring boot·分布式·微服务·性能优化