数据库--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;

}

相关推荐
Derek_Smart8 天前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
大道至简Edward8 天前
深入 JVM 核心:一文读懂 Class 文件结构(附 Hex 实战解析)
jvm
weisian15111 天前
JVM--20-面试题6:如何判断对象可以被垃圾回收?
jvm·可达性算法
蚊子码农11 天前
每日一题--JVM线程分析与死锁排查
jvm
xuxie9912 天前
NEXT 1 进程2
java·开发语言·jvm
weisian15112 天前
JVM--19-面试题5:说说JVM的类加载机制和双亲委派模型
jvm·双亲委派模型·jvm类加载机制
亓才孓12 天前
【反射机制】
java·javascript·jvm
Volunteer Technology12 天前
JVM之性能优化
jvm·python·性能优化
Andy Dennis12 天前
Java语法注意事项
java·开发语言·jvm
坚持的小马12 天前
JVM相关笔记-jps
jvm·笔记