数据库--Sqlite3

devtools/2024/9/23 21:20:42/

 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;
}
 


http://www.ppmy.cn/devtools/8079.html

相关文章

超星图书转成PDF格式

转为pdf 为避免浪费您的时间&#xff0c;本篇转载文章不值得花费您的宝贵时间阅读 方法一 感谢医学插画动画杜鹏 Roison An两位提供的方法&#xff0c;经试验后简化了一下&#xff0c;得出以下方法:1、使用超星打开你想要转换的图书2、依次打开本书的所有页面&#xff0c;不要…

【C数据结构】队列

文章目录 【 1. 基本原理 】【 2. 顺序队列 】【 3. 链队列 】3.1 结构体设计3.2 判断队列是否为空3.3 入队3.4 出队3.5 计算队列元素数量3.6 遍历输出元素3.7 实例 【 4. 循环队列 】4.1 真溢出、假溢出4.2 循环队列基本思想4.3 循环顺序队列结构体设计4.4 入队4.6 出队4.7 遍…

深度学习-优化策略

1.使用众所周知的梯度下降法。 &#xff08;1&#xff09;.批量梯度下降法&#xff1a;每次参数更新使用所有的样本&#xff08;2&#xff09;.随机梯度下降法&#xff1a;每次参数更新只使用一次样本&#xff08;3&#xff09;.小批量梯度下降法&#xff1a;每次参数更新使用…

黑马点评项目遇到的部分问题

目录 1. Invalid default value for ‘begin_time‘报错2. [ThreadLocal](https://blog.csdn.net/u010445301/article/details/111322569)3. 悲观锁实现单体一人一单超卖问题4. redisson5. 回顾秒杀优化6. Nginx 负载均衡 1. Invalid default value for ‘begin_time‘报错 my…

React中redux、react-redux、@reduxjs/toolkit状态管理库的使用方式

效果 下载依赖 npm install redux react-redux reduxjs/toolkit --save在src目录下创建文件 创建index.ts文件 import { configureStore } from reduxjs/toolkit import userSlice from ./userReducerconst store configureStore({reducer: {user: userSlice.reducer} }) //…

如何解决DDoS攻击?群联科技做出回答。

DDoS攻击&#xff08;分布式拒绝服务攻击&#xff09;是一种恶意利用多台傀儡机协同发起大规模网络流量&#xff0c;旨在压垮目标系统或网络资源&#xff0c;使其无法正常服务的网络攻击手段。由于现代计算机和网络性能的提升&#xff0c;单点发起的DoS攻击已难以奏效&#xff…

2440栈的实现类型、b系列指令、汇编掉用c、c调用汇编、切换工作模式、初始化异常向量表、中断处理、

我要成为嵌入式高手之4月11日51ARM第六天&#xff01;&#xff01; ———————————————————————————— b指令 标签&#xff1a;表示这条指令的名称&#xff0c;可跳转至标签 b指令&#xff1a;相当于goto&#xff0c;可随意跳转 如&#xff1a;fini…

不需要在 HTML 中添加任何额外的标签,就能实现复杂的设计效果。

1. 基础知识 什么是伪元素选择器 伪元素选择器用来指定一个元素的特定部分或者在元素中创建虚拟内容。 最常见的伪元素选择器包括 ::before 和 ::after&#xff0c;它们分别用于在元素内容的前面和后面添加内容或样式。 伪元素选择器是为了增强对元素的控制&#xff0c;它们…