1月2日作业

工人管理系统

#include<myhead.h>
#include<sqlite3.h>
sqlite3 * creat_sqlite()//创建数据库并返回数据库句柄
{const char *p="./my.db";sqlite3 *ppDb;if(sqlite3_open(p,&ppDb)!=SQLITE_OK)//调用数据库提供的第三方库函数{printf("打开数据库失败\n");printf("%s\n",sqlite3_errmsg(ppDb));//错误信息printf("%d\n",sqlite3_errcode(ppDb));//错误码printf("错误行:%d\n",__LINE__);perror("sqlite3_open");}return ppDb;//返回数据库句柄
}
void insert_worker(sqlite3 *ppDb)//插入员工信息
{char sql[1024];char *errmsg;//存储错误信息的指针sprintf(sql,"%s","create table work(num int primary key,name char,age int,salary int);");if(sqlite3_exec(ppDb,sql,NULL,NULL,&errmsg)!=SQLITE_OK)//执行sqlite语句的函数{printf("%s\n",sqlite3_errmsg(ppDb));//错误信息printf("%d\n",sqlite3_errcode(ppDb));//错误码printf("错误行:%d\n",__LINE__);}printf("创建表格成功\n");
}
void add_worker(sqlite3 *ppDb)//添加工人信息
{int num,age,salary;char name[50];char sql[1024];char *errmsg;//存储错误信息的指针printf("请输入工人编号: ");scanf("%d",&num);printf("请输入工人姓名: ");scanf("%s",name);printf("请输入工人年龄: ");scanf("%d",&age);printf("请输入工人工资: ");scanf("%d",&salary);sprintf(sql,"INSERT INTO work(num, name, age, salary) VALUES (%d,'%s',%d,%d);",num,name,age,salary);if(sqlite3_exec(ppDb,sql,NULL,NULL,&errmsg)!=SQLITE_OK) {printf("%s\n",sqlite3_errmsg(ppDb)); // 错误信息printf("%d\n",sqlite3_errcode(ppDb)); // 错误码printf("错误行:%d\n",__LINE__);}else{printf("添加工人信息成功\n");}
}
void update_worker(sqlite3 *ppDb) //修改工人信息
{int num,age,salary;char name[50];char sql[1024];char *errmsg; // 存储错误信息的指针printf("请输入要修改的工人编号: ");scanf("%d",&num);printf("请输入新的工人姓名: ");scanf("%s",name);printf("请输入新的工人年龄: ");scanf("%d",&age);printf("请输入新的工人工资: ");scanf("%d",&salary);sprintf(sql,"UPDATE work SET name='%s',age=%d,salary=%d WHERE num=%d;",name,age,salary,num);if(sqlite3_exec(ppDb,sql,NULL,NULL,&errmsg)!=SQLITE_OK) {printf("%s\n",sqlite3_errmsg(ppDb)); // 错误信息printf("%d\n",sqlite3_errcode(ppDb)); // 错误码printf("错误行:%d\n",__LINE__);}else{printf("修改工人信息成功\n");}
}
void show_all_workers(sqlite3 *ppDb) //展示所有信息
{char *errmsg; // 存储错误信息的指针char **result;int nrow,ncol;int i,j;char *sql="SELECT * FROM work;";if(sqlite3_get_table(ppDb,sql,&result,&nrow,&ncol,&errmsg)!=SQLITE_OK){printf("%s\n",sqlite3_errmsg(ppDb)); // 错误信息printf("%d\n",sqlite3_errcode(ppDb)); // 错误码printf("错误行:%d\n", __LINE__);}else{for(i=0;i<=nrow;i++){for(j=0;j<ncol;j++){printf("%s\t",result[i*ncol+j]);}printf("\n");}sqlite3_free_table(result); // 释放查询结果内存}
}
void delete_worker(sqlite3 *ppDb) //删除指定工人信息
{int num;char sql[1024];char *errmsg; // 存储错误信息的指针printf("请输入要删除的工人编号: ");scanf("%d",&num);sprintf(sql,"DELETE FROM work WHERE num=%d;",num);if(sqlite3_exec(ppDb,sql,NULL,NULL,&errmsg)!=SQLITE_OK) {printf("%s\n",sqlite3_errmsg(ppDb)); // 错误信息printf("%d\n",sqlite3_errcode(ppDb)); // 错误码printf("错误行:%d\n",__LINE__);}else{printf("删除工人信息成功\n");}
}
void delete_all_workers(sqlite3 *ppDb)//删除整表 
{char *errmsg; // 存储错误信息的指针char *sql="DROP TABLE work;";if(sqlite3_exec(ppDb,sql,NULL,NULL,&errmsg)!=SQLITE_OK) {printf("%s\n",sqlite3_errmsg(ppDb)); // 错误信息printf("%d\n",sqlite3_errcode(ppDb)); // 错误码printf("错误行:%d\n",__LINE__);}else{printf("删除整表成功\n");}
}
void menu()
{int ch;sqlite3 *ppDb;//数据库句柄while(1){printf("\t\t\t1、创建数据库\n");printf("\t\t\t2、添加工人信息\n");printf("\t\t\t3、修改工人信息\n");printf("\t\t\t4、展示所有信息\n");printf("\t\t\t5、删除指定工人信息\n");printf("\t\t\t6、删除整表\n");printf("\t\t\t0、退出\n");printf("请输入你的选择:");scanf("%d",&ch);getchar();switch(ch){case 1:ppDb=creat_sqlite();//创建数据库函数break;case 2:insert_worker(ppDb);add_worker(ppDb);//添加工人信息break;case 3:update_worker(ppDb);//修改工人信息break;case 4:show_all_workers(ppDb);//展示所有信息break;case 5:delete_worker(ppDb);//删除指定工人信息break;case 6:delete_all_workers(ppDb);//删除整表break;case 0:exit(0);break;}}
}
int main(int argc, const char *argv[])
{menu();//调用菜单函数return 0;
}

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

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

相关文章

职场常用Excel基础03-自定义排序

大家好&#xff0c;今天和大家一起分享一下excel中的自定义排序~ 通过排序&#xff0c;用户可以快速地对表格中的数据进行整理&#xff0c;以便更直观地观察趋势、查找特定信息或为后续的数据分析做准备。除了标准的升序和降序排序外&#xff0c;Excel还提供了强大的自定义排序…

批量读取pdf发票中二维码的信息

如下代码Java类&#xff1a; import com.alibaba.excel.EasyExcel; import com.alibaba.excel.ExcelWriter; import com.alibaba.excel.annotation.ExcelProperty; import com.alibaba.excel.write.builder.ExcelWriterBuilder; import com.alibaba.excel.write.metadata.Writ…

计算机网络-L2TP Over IPSec基础实验

一、概述 上次我们进行了标准L2TP的配置&#xff0c;但是在最后我们在进行业务流量访问时看到流量是没有进行加密的&#xff0c;这就导致可能得安全风险&#xff0c;所以这里其实可以退像GRE那样调用IPSec框架来进行加密保护。 拓扑 数据不加密 现在需要配置IPSec&#xff0c;然…

STLG_01_03_程序设计C语言 - 语法基础

C语言的语法基础是理解和使用C语言的关键。C语言的语法相对简洁&#xff0c;但功能强大。以下是C语言语法基础的主要内容&#xff1a; 一. 基本结构 1. 预处理指令&#xff1a;预处理指令以#开头&#xff0c;用于包含头文件、定义宏、条件编译等。 #include <stdio.h> …

C#控件开发4—仪表盘

目录 思路&#xff08;GDI绘图&#xff09;1.定义属性2.绘制图形3.最后生成&#xff08;自定义各种监控值显示&#xff09;End 如何让温度、湿度、压力等有量程的监控值如仪表盘&#xff08;DashBoard&#xff09;一样显示&#xff1f; 思路&#xff08;GDI绘图&#xff09; 定…

【内含代码】Spring Boot整合深度学习框架DJL

“ Deep Java Library是一个用于处理大规模数据处理和分析的强大工具包&#xff0c;它提供了丰富的数据结构和算法实现&#xff0c;支持高效的并行计算和分布式处理。Deep Java Library的设计目标是简化大规模数据处理任务的复杂性&#xff0c;提供高性能的计算能力&#xff0c…

ThinkPHP 8高效构建Web应用-第一个简单的MVC应用示例

【图书介绍】《ThinkPHP 8高效构建Web应用》-CSDN博客 《2025新书 ThinkPHP 8高效构建Web应用 编程与应用开发丛书 夏磊 清华大学出版社教材书籍 9787302678236 ThinkPHP 8高效构建Web应用》【摘要 书评 试读】- 京东图书 使用VS Code开发ThinkPHP项目-CSDN博客 我们先实现一…

数字化供应链创新解决方案在零售行业的应用研究——以开源AI智能名片S2B2C商城小程序为例

摘要&#xff1a; 在数字化转型的浪潮中&#xff0c;零售行业正经历着前所未有的变革。特别是在供应链管理方面&#xff0c;线上线下融合、数据孤岛、消费者需求多样化等问题日益凸显&#xff0c;对零售企业的运营效率与市场竞争力构成了严峻挑战。本文深入探讨了零售行业供应…

React基础知识学习

学习React前端框架是一个系统而深入的过程&#xff0c;以下是一份详细的学习指南&#xff1a; 一、React基础知识 React简介 React是一个用于构建用户界面的JavaScript库&#xff0c;由Facebook开发和维护。它强调组件化和声明式编程&#xff0c;使得构建复杂的用户界面变得更…

RabbitMQ - 4 ( 22000 字 RabbitMQ 入门级教程 )

一&#xff1a; RabbitMQ 高级特性 前面主要讲解了 RabbitMQ 的概念和应用。RabbitMQ 实现了 AMQP 0-9-1 规范&#xff0c;并在此基础上进行了多项扩展。在 RabbitMQ 官方网站中详细介绍了其特性&#xff0c;我们将其中一些重要且常用的特性挑选出来进行讲解。 1.1 消息确认 …

mac m2 安装 docker

文章目录 安装1.下载安装包2.在downloads中打开3.在启动台打开打开终端验证 修改国内镜像地址小结 安装 1.下载安装包 到官网下载适配的安装包&#xff1a;https://www.docker.com/products/docker-desktop/ 2.在downloads中打开 拖过去 3.在启动台打开 选择推荐设置 …

开发小技巧分享 01:JSON解析工具

1.百度词条 JSON&#xff08;JavaScript Object Notation&#xff0c;JavaScript对象表示法&#xff09;是基于ECMAScript的一个子集设计的&#xff0c;是一种开放标准的文件格式和数据交换格式&#xff0c;它易于人阅读和编写&#xff0c;同时也易于机器解析和生成。JSON独立于…

QT--------网络

实现思路 主机信息查询&#xff1a; 使用 QHostInfo 类可以查询主机名和 IP 地址信息。QNetworkInterface 类可以获取本地网络接口的信息&#xff0c;包括 IP 地址、子网掩码、广播地址等。 TCP 通信&#xff1a; 使用 QTcpServer 类实现 TCP 服务器端程序设计。使用 QTcpSock…

智能边缘计算×软硬件一体化:开启全场景效能革命新征程(企业开发者作品)

边缘智能技术快速迭代&#xff0c;并与行业深度融合。它正重塑产业格局&#xff0c;催生新产品、新体验&#xff0c;带动终端需求增长。为促进边缘智能技术的进步与发展&#xff0c;拓展开发者的思路与能力&#xff0c;挖掘边缘智能应用的创新与潜能&#xff0c;高通技术公司联…

C++ 设计模式:模板方法(Template Method)

链接&#xff1a;C 设计模式 链接&#xff1a;C 设计模式 - 策略模式 链接&#xff1a;C 设计模式 - 观察者模式 模板方法&#xff08;Template Method&#xff09;是一种行为设计模式&#xff0c;它定义了一个操作中的算法的骨架&#xff0c;而将一些步骤延迟到子类中。通过这…

docker Error response from daemon

问题 Error response from daemon: Get "https://index.docker.io/v1/search?qnginx&n25": read tcp 192.168.50.233:54354->54.198.86.24:443: read: connection reset by peer Unable to find image redis:latest locally docker: Error response from d…

数据挖掘——模型的评价

数据挖掘——模型的评价 模型的评价混淆矩阵ROC曲线如何构建ROC曲线 模型过分拟合和拟合不足减少泛化误差 模型的评价 混淆矩阵 准确率 a d a b c d \frac{ad}{abcd} abcdad​ T P T N T P T N F P F N \frac{TPTN}{TPTNFPFN} TPTNFPFNTPTN​ 其他度量&#xff1a; …

ubuntu 22.04安装ollama

1. 顺利的情况 按照官网的提示&#xff0c;执行下面的命令&#xff1a; curl -fsSL https://ollama.com/install.sh | sh如果网络畅通&#xff0c;github访问也没有问题&#xff0c;那就等待安装完成就行 2. 不顺利的情况 由于众所周知的情况&#xff0c;国内网络访问githu…

常用的数据结构API概览

List ArrayList 1、在初始化一个ArrayList的时候&#xff0c;如果我想同时set一些值 比如存放int[ ] List<int[]> list new ArrayList(Arrays.asList(new int[]{intervals[0][0],intervals[0][1]}));//或者int[] temp new int[]{intervals[0][0],intervals[0][1]}…

Pycharm 中 virtualenv、pipenv、conda 虚拟环境的用法

文章目录 前言虚拟环境的通俗介绍虚拟环境和非虚拟环境该怎么选?通过 Virtualenv 方式创建虚拟环境通过 Pipenv 方式创建虚拟环境通过 Conda 方式创建虚拟环境前言 在网上找了好一些资料,发现介绍 Pycharm 虚拟环境的不多,查了一些资料,并做个总结。 本文主要是介绍 Pycha…