数据库制作简易工人信息表

news2025/1/24 5:36:28

代码实现:

#include <head.h>

int add_msg(sqlite3* ppdb)
{
	int id;
	char name[20];
	int age;
	double salary;

	//输入要插入的工人信息
	printf("请输入工号:");
	scanf("%d",&id);
	printf("请输入姓名:");
	scanf("%s",name);
	printf("请输入年龄:");
	scanf("%d",&age);
	printf("请输入工资:");
	scanf("%lf",&salary);
	getchar();

	//准备sql语句
	char sql[128]="insert into Worker values(id,name,age,salary)";
	//将格式串转换为字符串
	sprintf(sql,"insert into Worker values(%d,'%s',%d,%.2lf);",id,name,age,salary);
	printf("sql=%s\n",sql);
	
	//定义储存错误信息的指针
	char* errmsg=NULL;
	//调用执行sql语句的函数
	sqlite3_exec(ppdb,sql,NULL,NULL,&errmsg);
	//释放
	sqlite3_free(errmsg);

	printf("insert success\n");
	
	return 0;
}

int delete_msg(sqlite3* ppdb)
{
	int id;
	printf("请输入要删除的信息id号:");
	scanf("%d",&id);
	getchar();

	//准备sql语句
	char sql[128]="";
	sprintf(sql,"delete from Worker where id=%d;",id);
	printf("sql=%s\n",sql);

	//定义储存错误信息的指针
	char* errmsg=NULL;
	//调用执行sql语句的函数
	sqlite3_exec(ppdb,sql,NULL,NULL,&errmsg);
	//释放
	sqlite3_free(errmsg);
	
	printf("delete success\n");

	return 0;
}

int update_msg(sqlite3* ppdb)
{
	int old_id;
	int new_id;
	char name[128]="";
	int age;
	double salary;
	printf("请输入要修改的信息id号:");
	scanf("%d",&old_id);
	printf("请输入修改的id号:");
	scanf("%d",&new_id);
	printf("请输入要修改的姓名:");
	scanf("%s",name);
	printf("请输入要修改的年龄:");
	scanf("%d",&age);
	printf("请输入要修改的薪资:");
	scanf("%lf",&salary);
	getchar();

	//准备sql语句
	char sql[128]="";
	sprintf(sql,"update Worker set id=%d,name='%s',age=%d,salary=%.2lf where id=%d;",new_id,name,age,salary,old_id);
	printf("sql=%s\n",sql);

	//定义储存错误信息的指针
	char* errmsg=NULL;
	//调用执行sql语句的函数
	sqlite3_exec(ppdb,sql,NULL,NULL,&errmsg);
	//释放
	sqlite3_free(errmsg);

	printf("update success\n");
	
	return 0;
}

//定义回调函数
int callback(void* arg,int cols,char** col_text,char** col_name)
{
	//打印表头
	if(*((int*)arg)==0)
	{
		(*((int*)arg))++;  //标识位自增
		for(int i=0;i<cols;i++)
		{
			printf("%5s\t",*(col_name+i));
		}
		putchar(10);
	}

	//打印数据
	for(int i=0;i<cols;i++)
	{
		printf("%5s\t",*(col_text+i));
	}
	putchar(10);

	return 0;
}

int search_msg(sqlite3* ppdb)
{
	//准备sql语句
	char sql[]="select * from Worker;";
	char* errmsg=NULL;

	int arg=0;  //标识位

	sqlite3_exec(ppdb,sql,callback,&arg,&errmsg);
	sqlite3_free(errmsg);
	
	printf("查找成功\n");
	return 0;
}

int main(int argc, const char *argv[])
{
	//1.打开数据库
	//定义句柄指针
	sqlite3* ppdb=NULL;
	if(sqlite3_open("my.db",&ppdb)!=SQLITE_OK)
	{
		fprintf(stderr,"sqlite3_open error,errcode:%d,errmsg:%s\n",sqlite3_errcode(ppdb),sqlite3_errmsg(ppdb));
		return -1;
	}
	printf("sqlite3_open success\n");

	//2.执行sql语句
	//2.1准备sql语句
	char sql[128]="create table if not exists Worker(id int primery key,name char,age int,salary double);";

	//2.2定义接收错误信息的指针
	char* errmsg=NULL;	
	
	if(sqlite3_exec(ppdb,sql,NULL,NULL,&errmsg)!=SQLITE_OK)
	{
		fprintf(stderr,"sqlite3_exec error:%s\n",errmsg);
		//释放errmsg的内存
		sqlite3_free(errmsg);
		return -1;
	}
	printf("create table success\n");

	//增删改查操作
	int menu;
	while(1)
	{
		system("clear");
		printf("=====员工信息管理=====\n");
		printf("=====1> 增加记录 =====\n");
		printf("=====2> 删除记录 =====\n");
		printf("=====3> 修改记录 =====\n");
		printf("=====4> 查找记录 =====\n");
		printf("=====0> 退出     =====\n");
		printf("请输入选项:");
		scanf("%d",&menu);
		getchar();  //吸收scanf留下的回车

		switch(menu)
		{
		case 1:
			{
				//增加记录
				add_msg(ppdb);
			}
			break;
		case 2:
			{
				//删除记录
				delete_msg(ppdb);
			}
			break;
		case 3:
			{
				//修改记录
				update_msg(ppdb);
			}
			break;
		case 4:
			{
				//查找记录
				search_msg(ppdb);
			}
			break;
		case 0: goto END;  //退出数据库操作
		default:printf("输入功能有误,请重新输入!\n");
		}
		//阻塞等待用户输入回车
		printf("输入任意字符结束>>>");
		while(getchar() != 10);
	}

END:

	//3.关闭数据库
	sqlite3_close(ppdb);
	
	return 0;
}

效果:

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

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

相关文章

idea 注入mapper报错报红的几种解决方案

文章目录 前言方法1&#xff1a;为 Autowired 注解设置required false方法2&#xff1a;用 Resource 替换 Autowired方法3&#xff1a;在Mapper接口上加上Repository注解方法4&#xff1a;用Lombok方法5&#xff1a;把IDEA的警告关闭掉方法6&#xff1a;不用管他 前言 相信大…

2015年第四届数学建模国际赛小美赛A题飞机上的细长座椅解题全过程文档及程序

2015年第四届数学建模国际赛小美赛 A题 飞机上的细长座椅 原题再现&#xff1a; 航空公司座位是指在旅途中乘客可以乘坐的座位。一些航空公司现在推出了新的经济舱“超薄”座位。这些座椅除了重量较轻外&#xff0c;理论上还允许航空公司在不显著影响乘客舒适度的情况下增加运…

Zookeeper的学习笔记

Zookeeper概念 Zookeeper是一个树形目录服务&#xff0c;简称zk。 Zookeeper是一个分布式的、开源的分布式应用程序的协调服务 Zookeeper提供主要的功能包括&#xff1a;配置管理&#xff0c;分布式锁&#xff0c;集群管理 Zookeeper命令操作 zk数据模型 zk中的每一个节点…

初识大数据,一文掌握大数据必备知识文集(3)

&#x1f3c6;作者简介&#xff0c;普修罗双战士&#xff0c;一直追求不断学习和成长&#xff0c;在技术的道路上持续探索和实践。 &#x1f3c6;多年互联网行业从业经验&#xff0c;历任核心研发工程师&#xff0c;项目技术负责人。 &#x1f389;欢迎 &#x1f44d;点赞✍评论…

SpringMVC基础知识(持续更新中~)

笔记&#xff1a; https://gitee.com/zhengguangqq/ssm-md/blob/master/ssm%20md%E6%A0%BC%E5%BC%8F%E7%AC%94%E8%AE%B0/%E4%B8%89%E3%80%81SpringMVC.md 细节补充&#xff1a; ​​​​​​​

你还不会排序算法吗

>欢迎关注博主 Mindtechnist 或加入【智能科技社区】一起学习和分享Linux、C、C、Python、Matlab&#xff0c;机器人运动控制、多机器人协作&#xff0c;智能优化算法&#xff0c;滤波估计、多传感器信息融合&#xff0c;机器学习&#xff0c;人工智能等相关领域的知识和技术…

用C实现字符串比较和用C实现字符串逆序输出-----(C每日一编程)

一&#xff0c;字符串比较 参考代码&#xff1a; int fun(char* p, char* q) {int i 0;while (*p *q) {if (*p \0)return 0;else p, q;}return *p - *q; } void main() {int n fun("goods", "people");printf("%d", n); }运行结果&#xf…

九州未来大模型一体机,加速AI应用落地

2023年已接近尾声&#xff0c;对于中国人工智能产业而言&#xff0c;这一年注定成为一个重要的转折点。在不同行业中&#xff0c;人工智能的应用不断涌现&#xff0c;众多大模型如雨后春笋般涌现。然而&#xff0c;在这一发展过程中也不可避免地出现了一系列问题&#xff0c;包…

Python电能质量扰动信号分类(二)基于CNN模型的一维信号分类

目录 前言 1 电能质量数据集制作与加载 1.1 导入数据 1.2 制作数据集 2 CNN-2D分类模型和训练、评估 2.1 定义CNN-2d分类模型 2.2 定义模型参数 2.3 模型结构 2.4 模型训练 2.5 模型评估 3 CNN-1D分类模型和训练、评估 3.1 定义CNN-1d分类模型 3.2 定义模型参数 …

六西格玛的科技漩涡——张驰咨询如何促成企业变革

在管理的海洋里&#xff0c;六西格玛管理是一艘稳健的航船&#xff0c;在质量管理的汪洋中乘风破浪&#xff0c;尽管质疑之声像远处的风暴不断逼近&#xff0c;但张驰咨询公司依靠这艘航船坚持初心&#xff0c;驭风而行。 20载耕耘&#xff0c;张驰咨询不仅仅是培养了超过8000…

C++_面向对象介绍

介绍 面向对象 What(为什么使用面向对象) 1.适合开发大型软件 2.数据抽象、代码复用、提升效率、降低成本 3.可利用已有现成的设计模式和应用框架Where(什么是面向对象) 1.将软件看成对象组成的空间&#xff0c;每个对象都拥有足够智能&#xff0c;能了解其他对象信息&#xf…

IntelliJ IDEA 2020将SpringMVC项目打成war包

一 、打开 Project Structure 进行配置 1. 打开方式 &#xff08;1&#xff09;CtrlAltShiftS &#xff08;2&#xff09;File->Project Structure &#xff08;3&#xff09;点击如下图标&#xff1a; 2. 进入 Project Structure&#xff0c;添加Artifacts Web Applica…

【每日一题】得到山形数组的最少删除次数

文章目录 Tag题目来源解题思路方法一&#xff1a;最长递增子序列 写在最后 Tag 【最长递增子序列】【数组】【2023-12-22】 题目来源 1671. 得到山形数组的最少删除次数 解题思路 方法一&#xff1a;最长递增子序列 前后缀分解 根据前后缀思想&#xff0c;以 nums[i] 为山…

第11章 GUI Page417~418 步骤五 支持方框

运行效果&#xff1a; 关键代码&#xff1a; 添加头文件&#xff1a;item_rectangle.hpp //item_rectangle.hpp #ifndef ITEM_RECTANGLE_HPP_INCLUDED #define ITEM_RECTANGLE_HPP_INCLUDED #include "item_i.hpp"class RectangleItem : public IItem { public:Rec…

C语言struct,union内存对齐

测试环境&#xff1a; #include<stdio.h> int main(){//1字节对齐struct XXX{unsigned char ch;unsigned int in;unsigned short si;}__attribute__((packed));struct XXX xxx;printf("%zd\n",sizeof(xxx));//7#pragma pack(1)struct YYY{unsigned char ch;u…

java-sec-code中rmi

java-sec-code中rmi 暂时没有搞懂原理&#xff0c;这里只说明利用方法 java-sec-code 作者给出的是使用ysoserial进行利用 测试环境搭建 docker环境下&#xff0c;1099端口默认不开启&#xff0c;这里使用idea运行org.joychou.RMI.Server即可 个人电脑java环境分为1.8.381 1.8.…

Linux下编写zlg7290驱动(3)-键盘驱动编写

2.3. 数据处理实现 执行上述代码后系统中就注册了我们的input设备&#xff0c;接下来我们要做的是活得键盘的键值&#xff0c;zlg7290多可以支持64个按键&#xff0c;每个按键按下后都会产生一个中断&#xff0c;我们写驱动是可以使用轮询不断检测是否有按键也可以触发中断来判…

2024年PMP考试新考纲-PMBOK第七版-项目管理原则真题解析(续1)

从战争中学习战争。对于参加2024年PMP考试的小伙伴来说&#xff0c;最有效的学习方式是这样地&#xff1a;①阅读了教材&#xff08;PMBOK6、7和敏捷&#xff09;&#xff0c;了解基本概念&#xff1b;②反复刷近期的PMP考试真题&#xff0c;查漏补缺。 自从PMI和中国国际人才…

智能优化算法应用:基于鹰栖息算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于鹰栖息算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于鹰栖息算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.鹰栖息算法4.实验参数设定5.算法结果6.参考文…

Linux内核编码规范

学习linux内核或者linux驱动的人应该先掌握内核编码规范&#xff0c;这样才能更好的驾驭linux内核、驱动。 下面就从这几个方面讲解一下linux内核编码规范。 注释风格、排版风格、头文件风格、变量定义、宏定义、函数 1 注释风格 1.1 注释的原则是有助于对程序的阅读和理解&…