3.6作业

作业要求:数据库操作的增、删、改

程序代码:

#include<myhead.h>
int main(int argc, const char *argv[])
{//定义数据库句柄指针sqlite3 * ppDb = NULL;//打开数据库,如果数据库不存在,则创建数据库//将数据库句柄由参数2返回if(sqlite3_open("./stu.db",&ppDb) != 0){printf("sqlite3_open error,errcode=%d,errmsg=%s\n",sqlite3_errcode(ppDb),sqlite3_errmsg(ppDb));return -1;}printf("sqlite3_open success\n");//创建数据表//1.准备sql语句char sql[128] ="create table if not exists worker(numb int ,name char,salary double)";char *errmsg = NULL;               //存放执行sql语句中的错误信息if(sqlite3_exec(ppDb , sql , NULL , NULL , &errmsg) != SQLITE_OK){printf("exec error : %s\n",errmsg);sqlite3_free(errmsg);                  //防止内存泄漏errmsg = NULL;return -1;}printf("员工信息表创建成功\n");int menu = -1;               //菜单选项	for(;;){system("clear");             //清空之前的终端信息printf("\t\t======公司员工管理系统======\n");printf("\t\t======1.添加员工信息======\n");printf("\t\t======2.删除员工信息======\n");printf("\t\t======3.修改员工信息======\n");printf("\t\t======4.查询员工信息======\n");printf("\t\t======5.退出======\n");printf("请输入操作码:");           //提示并输入信息scanf("%d",&menu);getchar();                            //吸收回车switch(menu){case 1:{char ch[64];char *errmsg = NULL;printf("请按照格式输入:  (numb,'name',salary)\n");fgets(ch,sizeof(ch),stdin);char buf[128] = "insert into worker values";strcat(buf,ch);if(sqlite3_exec(ppDb , buf , NULL , NULL , &errmsg) != SQLITE_OK){printf("insert error : %s\n",errmsg);sqlite3_free(errmsg);                  //防止内存泄漏errmsg = NULL;return -1;}printf("员工信息添加成功\n");}break;case 2:{char ch[64];char *errmsg = NULL;printf("请按照格式输入:  'name'\n");fgets(ch,sizeof(ch),stdin);char buf[128] = "delete from worker where name=";strcat(buf,ch);if(sqlite3_exec(ppDb , buf , NULL , NULL , &errmsg) != SQLITE_OK){printf("delete error : %s\n",errmsg);sqlite3_free(errmsg);                  //防止内存泄漏errmsg = NULL;return -1;}printf("员工信息删除成功\n");}break;case 3:{for(;;){system("clear");             //清空之前的终端信息printf("\t\t======修改员工信息======\n");printf("\t\t======1.修改员工numb信息======\n");printf("\t\t======2.修改员工salary信息======\n");printf("\t\t======3.退出======\n");printf("请输入操作码:");           //提示并输入信息scanf("%d",&menu);getchar();                            //吸收回车switch(menu){case 1:{char ch[64];char *errmsg = NULL;printf("请按照格式输入:numb where name='name'\n");fgets(ch,sizeof(ch),stdin);char buf[128] = "update worker set numb=";strcat(buf,ch);if(sqlite3_exec(ppDb , buf , NULL , NULL , &errmsg) != SQLITE_OK){printf("update error : %s\n",errmsg);sqlite3_free(errmsg);                  //防止内存泄漏errmsg = NULL;return -1;}printf("员工numb信息修改成功\n");}break;case 2:{char ch[64];char *errmsg = NULL;printf("请按照格式输入:salary where name='name'\n");fgets(ch,sizeof(ch),stdin);char buf[128] = "update worker set salary=";strcat(buf,ch);if(sqlite3_exec(ppDb , buf , NULL , NULL , &errmsg) != SQLITE_OK){printf("update error : %s\n",errmsg);sqlite3_free(errmsg);                  //防止内存泄漏errmsg = NULL;return -1;}printf("员工salary信息修改成功\n");}break;case 3:goto end;}}}break;
end:break;case 4:{//查找员工信息}break;case 5:goto END;default:printf("您输入的功能有误,请重新输入!!!\n");}printf("请输入任意键,按回车清屏\n");while(getchar() != '\n');}
END://关闭数据库sqlite3_close(ppDb);return 0;
}

运行结果:

添加员工信息:

删除员工信息:

修改员工信息:

总运行结果:

课程总结:

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Leetcode每日一刷】数组|704. 二分查找、27. 移除元素

力扣每日刷题 一、704. 二分查找1.1、题目1.2、解题思路1.3、代码实现——C1.4、 总结&易错 二、27. 移除元素2.1&#xff1a;题目2.2、解题思路2.3、代码实现——C1.4、 总结&易错 一、704. 二分查找 1.1、题目 704. 二分查找 1.2、解题思路 题型&#xff1a;数组…

2024年洗地机推荐,希亦、美的、西屋、顺造洗地机哪个品牌最耐用质量好?

对许多人来说&#xff0c;全屋清洁可能是件让人望而却步的任务&#xff0c;因为它需要花费大量的体力和时间。但是&#xff0c;随着科技的发展&#xff0c;我们可以找到一些能够简化这个过程的神器&#xff0c;比如洗地机。有了洗地机&#xff0c;我们可以轻松地完成扫地、拖地…

【CSP试题回顾】201509-1-数列分段

CSP-201509-1-数列分段 解题代码 #include <iostream> #include <vector> #include <algorithm> using namespace std;int n, t, maxSeg 0;int main() {cin >> n;vector<int>list(n);for (int i 0; i < n; i){cin >> list[i];}auto…

JavaBoy假期如何学习项目?弯道块才是真的快!

至暗时刻 老话说的好&#xff0c;弯道快才是真的快&#xff0c;谁直线不会加油&#xff1f;每到假期都是在座的各位弯道超车的时候。转眼自己已经出来搬了快四年砖头了&#xff0c;偶尔访问下牛客发现行情真是一年不如一年。。。不由得回想起自己春招时候的经历。 回想起2020年…

HI3519DV500 HI3519DRFCV500 HI3519DRBCV500 海思安防监控芯片 提供原厂开发包

一、总体介绍 Hi3519DV500是一颗面向视觉行业推出的超 高清智能 SoC。该芯片最高支持四路sensor输 入&#xff0c;支持最高4K30fps的ISP图像处理能力&#xff0c;支持 2F WDR、多级降噪、六轴防抖、全景拼接、多光 谱融合等多种传统图像增强和处理算法&#xff0c;支持通过AI…

浏览器发出一个请求到收到响应步骤详解

前言 在网络通信中&#xff0c;浏览器向Web服务器发送HTTP请求消息的过程是一个复杂而精密的环节&#xff0c;涉及到URL解析、DNS解析、数据拆分、路由表规则和MAC头部添加等一系列步骤。本文将深入探讨这一过程的每个环节&#xff0c;帮助读者更全面地了解浏览器与Web服务器之…

双体系Java学习之关键字,标识符以及命名规范

重新开始从Java基础开始学&#xff0c;保持每周两更的状态&#xff0c;刚开学事情有点多。 关键字 标识符 命名规范

docker 安装 portainer

小编给友友们总结了一下 Portainer 的好处以下 Portainer是Docker的图形化管理工具&#xff0c;提供状态显示面板、应用模板快速部署、容器镜像网络数据卷的基本操作&#xff08;包括上传下载镜像&#xff0c;创建容器等操作&#xff09;、事件日志显示、容器控制台操作、Swar…

STM32CubeIDE基础学习-安装芯片固件支持包

STM32CubeIDE基础学习-添加芯片固件支持包 前言 前面的文章在安装STM32CubeIDE软件时没有安装这个芯片PACK包&#xff0c;如果工程没有这个固件支持包的话是无法正常使用的&#xff0c;随便安装一个和芯片对应系列的支持包就可以了。 这篇文章来记录一下新增PACK包的常用操作…

13【CPP】Hash(闭散列||开散列)

闭散列 闭散列&#xff1a;也叫开放定址法&#xff0c;当发生哈希冲突时&#xff0c;如果哈希表未被装满&#xff0c;说明在哈希表中必然还有 空位置&#xff0c;那么可以把key存放到冲突位置中的“下一个” 空位置中去。 线性探测 需要定义三个状态&#xff0c;空、删除、存…

备战蓝桥杯————二分搜索(一)

引言 一、二分查找 基本概念 代码框架 二、二分查找 题目描述 解题思路及代码 结果展示 三、寻找左侧边界的二分搜索 使用背景 基本代码 引言 在计算机科学的世界里&#xff0c;二分查找算法无疑是一种经典且强大的工具。它以其高效的性能&#xff0c;在有序数据集中…

Windows10安装Docker

使用 PowerShell 启用 Hyper-V 以管理员身份打开 PowerShell 控制台。 运行以下命令&#xff1a; PowerShell复制 Enable-WindowsOptionalFeature -Online -FeatureName Microsoft-Hyper-V -All如果无法找到此命令&#xff0c;请确保你以管理员身份运行 PowerShell。 安装…

Android大厂高级面试题灵魂100问,带你彻底弄明白

“2020年技术没有成长&#xff0c;我今年一定要好好努力学习&#xff01;” “在现在这个公司都工作了3年了&#xff0c;一毛钱工资都没有涨…” “年前真倒霉&#xff0c;老板嫌我工资高&#xff0c;被优化了&#xff0c;年后又遇到了疫情&#xff0c;现在都还没有找到合适的工…

从Win转Mac,我的感受如何

文章目录 前言MacBook优点美观动画流畅安装软件方便轻便、续航强大多数命令和Linux通用系统稳定、安全做工精美、视听体验好CPU性能较好触控板体验好 MacBook缺点缺乏部分软件部分操作逻辑不是很科学&#xff1f;玩不了多少游戏 总结与展望 前言 整个大学期间&#xff0c;我的主…

【论文翻译】结构化状态空间模型

文章目录 3.2 对角结构化状态空间模型3.2.1 S4D:对角SSM算法3.2.2 完整应用实例 3.3 对角化加低秩&#xff08;DPLR&#xff09;参数化3.3.1 DPLR 状态空间核算法3.3.2 S4-DPLR 算法和计算复杂度3.3.3赫尔维兹&#xff08;稳定&#xff09;DPLR形式 这篇文章是Mamba作者博士论文…

LLM量化、高保真图生视频、多模态肢体运动生成、高分辨率图像合成、低光图像/视频增强、相机相对姿态估计

本文首发于公众号&#xff1a;机器感知 LLM量化、高保真图生视频、多模态肢体运动生成、高分辨率图像合成、低光图像/视频增强、相机相对姿态估计 EasyQuant: An Efficient Data-free Quantization Algorithm for LLMs Large language models (LLMs) have proven to be very s…

android实战视频教程,flutter开发实战详解pdf

前言 这是一篇软文、但是绝对不是鸡汤&#xff1b;为啥不是呢&#xff1f;因为我文笔太差…偶尔矫情发发牢骚&#xff08;勿喷&#xff09; 说说程序猿行业 现在社会上给IT行业贴上了几个标签&#xff1a;高薪、高危、高大上、秃顶&#xff08;哈哈&#xff09;。这些标签我…

C++的类与对象(三)

目录 类的6个默认成员函数 构造函数 语法 特性 析构函数 特性 类的6个默认成员函数 问题&#xff1a;一个什么成员都没的类叫做空类&#xff0c;空类中真的什么都没有吗&#xff1f; 基本概念&#xff1a;任何类在什么都不写时&#xff0c;编译器会自动生成以下六个默认…

Linux 性能优化的全景指南,都在这一篇里了,建议收藏!

Linux 性能优化 性能指标 高并发和响应快对应着性能优化的两个核心指标&#xff1a;吞吐和延时 应用负载角度&#xff1a;直接影响了产品终端的用户体验 系统资源角度&#xff1a;资源使用率、饱和度等 性能问题的本质就是系统资源已经到达瓶颈&#xff0c;但请求的处理还…

MySQL下实现纯SQL语句的递归查询

需求 有一个部门表&#xff0c;部门表中有一个字段用于定义它的父部门&#xff1b; 在实际业务中有一个『部门中心』的业务&#xff1b; 比如采购单&#xff0c;我们需要显示本部门及子部门的采购单显示出来。 结构 数据如下&#xff1a; 实现方式如下&#xff1a; WITH RECUR…