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还提供了强大的自定义排序…

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

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

C#控件开发4—仪表盘

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

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;对零售企业的运营效率与市场竞争力构成了严峻挑战。本文深入探讨了零售行业供应…

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.在启动台打开 选择推荐设置 …

QT--------网络

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

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

边缘智能技术快速迭代&#xff0c;并与行业深度融合。它正重塑产业格局&#xff0c;催生新产品、新体验&#xff0c;带动终端需求增长。为促进边缘智能技术的进步与发展&#xff0c;拓展开发者的思路与能力&#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; …

常用的数据结构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]}…

OceanBase到MySQL实时同步方案

概述 本方案基于OceanBase Binlog服务&#xff0c;采用数据库实时复制软件Beedup订阅捕获OceanBase数据库的Binlog事件&#xff0c;复制软件将Binlog事件还原为MySQL支持的DML或DDL&#xff0c;然后交由MySQL数据库执行。 配置Binlog任务 启用OceanBase Binlog服务&#xff…

【数据库系统概论】绪论--复习

1. 数据库的四个基本概念 数据&#xff1a;指经过处理的、可用于计算机操作的原始信息&#xff08;或者也可以理解成是——描述事务的符号&#xff0c;数字、图像、符号、音频、视频、文字、图形等都可以是数据&#xff09;。数据库&#xff1a;是长期存储在计算机内有组织、可…

Git 下载问题及解决方法

在某些网络环境下&#xff0c;可能会遇到 Git 无法下载的问题&#xff0c;通常是由于网络限制或需要通过代理访问导致的。以下是常见的解决方法&#xff0c;包括设置代理、取消代理以及其他诊断方法。 1. 设置 Git 代理 在一些网络环境下&#xff0c;可能会使用工具&#xff0…

《从入门到精通:蓝桥杯编程大赛知识点全攻略》(一)-递归实现指数型枚举、递归实现排列型枚举

本篇博客将聚焦于通过递归来实现两种经典的枚举方法&#xff1a;指数型枚举和排列型枚举。这两种枚举方式在计算机科学和算法竞赛中都有广泛应用&#xff0c;无论是在解题中&#xff0c;还是在实际工作中都极具价值。 目录 前言 斐波那契数列递归 递归实现指数型枚举 算法思…

大模型 LangChain 开发框架-初探

大模型 LangChain 开发框架-初探 一、LangChain 概述 LangChain 是一个强大的由大型语言模型&#xff08;LLM&#xff09;驱动的应用程序开发框架。它的核心价值在于提供了标准化组件接口、高效的任务编排能力以及可观察性和评估机制。通过这些特性&#xff0c;LangChain 有效…

生成埃里克卡特曼人工智能语音听起来像他或配音视频

您是《南方公园》和迷人角色埃里克卡特曼的忠实粉丝吗&#xff1f;您是否渴望获得标志性的埃里克卡特曼 AI 语音&#xff0c;将他的动画魅力融入到您的数字内容、游戏或流媒体体验中&#xff1f;如果答案是肯定的&#xff0c;那么您来对地方了&#xff01; 在本文中&#xff0…

BLDC无感控制的驱动逻辑

如何知道转子已经到达预定位置&#xff0c;因为我们只有知道了转子到达了预定位置之后才能进行换相&#xff0c;这样电机才能顺滑的运转。转子位置检测常用的有三种方式。 方式一&#xff1a;通过过零检测&#xff0c;三相相电压与电机中性点电压进行比较。过零检测的优点在于…

【Vue教程】使用Vite快速搭建前端工程化项目 | Vue3 | Vite | Node.js

&#x1f64b;大家好&#xff01;我是毛毛张! &#x1f308;个人首页&#xff1a; 神马都会亿点点的毛毛张 &#x1f6a9;今天毛毛张分享的是关于如何快速&#x1f3c3;‍♂️搭建一个前端工程化的项目的环境搭建以及流程&#x1f320; 文章目录 1.前端工程化环境搭建&#…