网络编程day6

#include <myhead.h>
void Insert_Record(sqlite3* ppDb); // 插入记录
void Delete_Record(sqlite3* ppDb); // 删除记录
void Update_Record(sqlite3* ppDb); // 修改记录
int main(int argc, const char *argv[])
{
//1、定义一个数据库句柄指针
    sqlite3 * ppDb = NULL;

    //2、创建或打开数据库
    if(sqlite3_open("./mydb.db", &ppDb) != SQLITE_OK)
    {
        printf("sqlite3_open error:%s,errcode = %d\n", sqlite3_errmsg(ppDb), sqlite3_errcode(ppDb));
        return -1;
    }
    printf("数据库打开成功\n");

    //3、创建数据表
    //3.1 准备sql语句
    char sql[128] = "create table if not exists Stu(numb int, name char, sex char, socre double);";
    char *errmsg = NULL;

    //3.2 执行sql语句
    if(sqlite3_exec(ppDb, sql, NULL, NULL, &errmsg) != SQLITE_OK)
    {
        printf("%s\n", errmsg);
        return -1;
    }
    printf("数据表创建成功\n");

    int choice;
  while (1)
  {
        printf("\n---------------------\n");
        printf("-------1. 插入-------\n");
        printf("-------2. 删除-------\n");
        printf("-------3. 修改-------\n");
        printf("-------4. 查询-------\n");
        printf("-------5. 退出-------\n");
        printf("---------------------\n\n");
 
        printf("请选择你要执行的功能>>> ");
 
        scanf("%d", &choice);
        switch (choice)
		{
        case 1:
            Insert_Record(ppDb);
            break;
        case 2:
            Delete_Record(ppDb);
            break;
        case 3:
            Update_Record(ppDb);
            break;
        case 4:
            break;
        case 5:
            exit(EXIT_SUCCESS);
            break;
        default:
            printf("\n输入格式错误!!!\n请在功能1 2 3 4 5中选择!!!\n\n");
            sleep(1);
            break;
        }
    }

    //关闭数据库
    sqlite3_close(ppDb);
	return 0;
}
// 插入记录
void Insert_Record(sqlite3* ppDb)
{
    int numb;
	char sex[16];
    char name[20];
    double score;
    char sql[128];
    char* errmsg = NULL;
    printf("请输入学号:");
    scanf("%d", &numb);   
	printf("请输入姓名:");
    scanf("%s", name);
	printf("请输入性别:");
	scanf("%s", sex);
    printf("请输入分数:");
    scanf("%lf", &score);
    sprintf(sql, "INSERT INTO stu VALUES (%d,\"%s\",\"%s\",%lf);", numb, name, sex, score);
    if (sqlite3_exec(ppDb, sql, NULL, NULL, &errmsg) != SQLITE_OK) 
	{
        printf("insert record error : %s\n", errmsg);
        return;
    }
    printf("插入成功\n");
}
 
// 删除记录
void Delete_Record(sqlite3* ppDb)
{
    char sql[128];
    int numb;
    char* errmsg = NULL;
    printf("请输入删除记录的numb值:");
    scanf("%d", &numb);
    sprintf(sql, "DELETE FROM stu WHERE numb=%d", numb);
    if (sqlite3_exec(ppDb, sql, NULL, NULL, &errmsg) != SQLITE_OK) {
        printf("delete record error %s\n", errmsg);
        return;
    }
    printf("删除成功\n");
}
 
// 修改记录
void Update_Record(sqlite3* ppDb)
{
    int choice;
    char sql[128];
    int numb;
    char name[20];
	char sex[20];
    int limit_numb;
    double score;
    char* errmsg = NULL;
    printf("请输入修改记录的numb值:");
    scanf("%d", &limit_numb);
 
    printf("\n---------------------\n");
    printf("--------1. numb--------\n");
    printf("-------2. name-------\n");
    printf("-------3. sex-------\n");
	printf("-------4. score------\n");
    printf("---------------------\n\n");
 
    printf("请选择要修改记录的字段>>> ");
    scanf("%d", &choice);
    if (choice == 1)
	{
        printf("请输入修改后的numb:");
        scanf("%d", &numb);
        sprintf(sql, "UPDATE stu SET numb=%d WHERE numb=%d", numb, limit_numb);
    }
	else if (choice == 2)
	{
        printf("请输入修改后的name:");
        scanf("%s", name);
        sprintf(sql, "UPDATE stu SET name=\"%s\" WHERE numb=%d", name, limit_numb);
    }
	else if (choice == 3)
	{
        printf("请输入修改后的sex:");
        scanf("%s", sex);
        sprintf(sql, "UPDATE stu SET sex=\"%s\" WHERE numb=%d", sex, limit_numb);
    }

	else if (choice == 4)
	{
        printf("请输入修改后的score:");
        scanf("%lf", &score);
        sprintf(sql, "UPDATE stu SET score=%lf WHERE numb=%d", score, limit_numb);
    }
 
    if (sqlite3_exec(ppDb, sql, NULL, NULL, &errmsg) != SQLITE_OK) {
        printf("update record error: %s\n", errmsg);
        return;
    }
    printf("修改成功\n");
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/555222.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

面试经典150题——相同的树

​ 1. 题目描述 2. 题目分析与解析 要编写一个判断两棵二叉树是否完全相同的代码&#xff0c;首先需要理解何谓“完全相同”的二叉树。完全相同意味着两棵树的结构完全一致&#xff0c;并且所有对应的节点上的值也必须相同。 1. 定义问题 首先明确问题定义&#xff1a;给定…

RC4Drop加密技术:原理、实践与安全性探究

title: RC4Drop加密技术&#xff1a;原理、实践与安全性探究 date: 2024/4/18 20:47:30 updated: 2024/4/18 20:47:30 tags: RC4算法流加密安全性RC4Drop技术密钥流加密解密网络通信 第一章&#xff1a;介绍 1.1 加密技术的重要性 加密技术在当今信息社会中扮演着至关重要的…

R语言计算:t分布及t检验

t分布理论基础 t分布也称Student’s t-distribution&#xff0c;主要出现在小样本统计推断中&#xff0c;特别是当样本量较小且总体标准差未知时&#xff0c;用于估计正态分布的均值。其定义基于正态分布和 X 2 X^{2} X2分布&#xff08;卡方分布&#xff09;。如果随机变量X服…

Matlab r2023b Simulink 给子系统添加封面

写这篇记录的原因是&#xff0c;r2023b版本里改动了自定义封面的界面&#xff0c;而我是一个新手小白&#xff0c;零基础&#xff0c;探索一天之后发现实现方法。最终效果如图&#xff1a; 步骤1&#xff1a;打开软件&#xff0c;点击Simulink&#xff0c;再打开含有子系统的工…

【基础】在GCC中编译和链接不是一个命令

在 GCC&#xff08;GNU Compiler Collection&#xff09;中&#xff0c;编译和链接不是一个命令。编译是将源代码转换为目标代码的过程。它主要进行语法检查、词法分析、生成中间代码等操作。链接是将多个目标文件和库文件组合成一个可执行文件的过程。在 GCC 中&#xff0c;通…

Cesium实现加载离线地形数据(nginx发布数据,cesiumLab地形切片数据)

实现效果如图&#xff1a; 详细步骤 1 下载地形数据&#xff08;DEM&#xff09; 下载地址&#xff1a;地理空间数据云 (gscloud.cn) 操作步骤&#xff1a; 注意&#xff1a;第3步可以自主选择DEM的分辨率&#xff0c;然后下载。 下载结果解压后如下图&#xff1a; 2 使用…

C语言 递归

递归指的是在函数的定义中使用函数自身的方法。 举个例子&#xff1a; 从前有座山&#xff0c;山里有座庙&#xff0c;庙里有个老和尚&#xff0c;正在给小和尚讲故事呢&#xff01;故事是什么呢&#xff1f;“从前有座山&#xff0c;山里有座庙&#xff0c;庙里有个老和尚&…

python3高级特性

1. 装饰器 装饰器是 Python 的一种高阶函数&#xff0c;它可以在不修改函数内部代码的情况下&#xff0c;给函数增加额外的功能。 案例&#xff1a;记录函数执行时间的装饰器 import time def timing_decorator(func): def wrapper(*args, **kwargs): start_time time.t…

lua学习笔记18(面相对象之多态)

print("*****************************面相对象多态*******************************") --相同方法不同执行逻辑 object{} object.id1 function object:new()local obj{}self.__indexself setmetatable(obj,self)return obj end function object:subClass(className)…

PLC程序远程上下载

在工业自动化领域&#xff0c;PLC&#xff08;可编程逻辑控制器&#xff09;扮演着至关重要的角色。然而&#xff0c;传统的PLC程序上传与下载方式往往受限于物理距离和现场环境&#xff0c;给工程师们带来了诸多不便。如今&#xff0c;随着远程技术的不断发展&#xff0c;PLC程…

基于XML配置bean(一)

文章目录 1.获取bean的两种方式1.通过id获取bean&#xff08;前面用过&#xff09;2.通过类型获取bean&#xff08;单例时使用&#xff09;1.案例2.代码1.beans.xml2.SpringBeanTest.java3.结果 3.注意事项 2.三种基本依赖注入方式1.通过属性配置bean&#xff08;前面用过&…

Eureka基础介绍和使用

目录 一.理论基础 二.父项目 2.1 新建父项目 2.2 管理依赖 三.子项目 3.1 新建子项目 3.2 注册中心Server依赖和启动类和配置文件 3.3 生产者Client 依赖和启动类和配置文件 3.5 消费者Custmer依赖和配置类、启动类和配置文件 四.心跳 五.公共资源项目 5.1新建实体…

BUG:vue表单验证校验不报错,必填都有信息,就是不能正常往下进行

vue表单验证未报错却出现异常 框架bug场景解决办法 框架 UI&#xff1a;element-UI 前端&#xff1a;vue2 bug场景 正常表单里面&#xff0c;有的信息要求必填或者加了一些限制&#xff0c;作为校验验证&#xff0c;只有走到校验才会执行其他行为&#xff0c;比如调用保存接…

labelimg安装和使用(解决闪退问题)

&#x1f308;个人主页&#xff1a;Rookie Maker &#x1f525; 系列专栏&#xff1a;计算机视觉 &#x1f3c6;&#x1f3c6;关注博主&#xff0c;随时获取更多关于IT的优质内容&#xff01;&#x1f3c6;&#x1f3c6; &#x1f600;欢迎来到我的代码世界~ &#x1f601; 喜…

C++修炼之路之list--C++中的双向循环链表

目录 前言 一&#xff1a;正式之前先回顾数据结构中的双向循环链表 二&#xff1a;list的简介 三&#xff1a;STL中list常用接口函数的介绍及使用 1.构造函数接口 2.list迭代器 范围for 3.数据的修改接口函数 4.list容量操作函数 5.list的迭代器失效 6.演示代码和测…

【网络编程】Web服务器shttpd源码剖析——线程池调度

hello &#xff01;大家好呀&#xff01; 欢迎大家来到我的网络编程系列之web服务器shttpd源码剖析——线程池调度&#xff0c;在这篇文章中&#xff0c;你将会学习到在Linux内核中如何创建一个自己的并发服务器shttpd&#xff0c;并且我会给出源码进行剖析&#xff0c;以及手绘…

allure2教程-3-测试报告定制

领取资料&#xff0c;咨询答疑&#xff0c;请➕wei: June__Go 上一小节&#xff0c;我们学习一下pytestallure2生成html测试报告的方法&#xff0c;本小节我们学习一下allure2测试报告的定制。 allure2报告预览 预览网址&#xff1a;https://demo.qameta.io/allure/# allur…

[leetcode] minimum-falling-path-sum

. - 力扣&#xff08;LeetCode&#xff09; 给你一个 n x n 的 方形 整数数组 matrix &#xff0c;请你找出并返回通过 matrix 的下降路径 的 最小和 。 下降路径 可以从第一行中的任何元素开始&#xff0c;并从每一行中选择一个元素。在下一行选择的元素和当前行所选元素最多…

归并排序了解吗?手撕一个我看看?

目录 1- 归并排序原理1-1 主要思想1-2 实现步骤 2- 归并排序代码实现(双指针)⭐ 归并排序 ——实现思路 3- ACM模式实现 1- 归并排序原理 1-1 主要思想 归并排序基于分治 将序列中待排序的数数字分为若干组&#xff0c;每个数字分为一组 将若干组两两合并&#xff0c;保证合…

3D模型处理的多进程并行【Python】

今天我们将讨论如何使用 Python 多进程来处理大量3D数据。 我将讲述一些可能在手册中找到的一般信息&#xff0c;并分享我发现的一些小技巧&#xff0c;例如将 tqdm 与多处理 imap 结合使用以及并行处理存档。 NSDT工具推荐&#xff1a; Three.js AI纹理开发包 - YOLO合成数据生…