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;
}

相关推荐
爬山算法7 小时前
Redis(144)Redis的Cluster的节点通信是如何实现的?
数据库·redis·缓存
AI绘画小338 小时前
Web 安全核心真相:别太相信任何人!40 个漏洞挖掘实战清单,直接套用!
前端·数据库·测试工具·安全·web安全·网络安全·黑客
I***26158 小时前
数据库操作与数据管理——Rust 与 SQLite 的集成
数据库·rust·sqlite
百***48078 小时前
redis连接服务
数据库·redis·bootstrap
C***11509 小时前
对基因列表中批量的基因进行GO和KEGG注释
开发语言·数据库·golang
小蒜学长9 小时前
基于spring boot的汽车4s店管理系统(代码+数据库+LW)
java·数据库·spring boot·后端·汽车
一 乐9 小时前
餐厅管理智能点餐系统|基于java+ Springboot的餐厅管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端
gAlAxy...9 小时前
SpringMVC 响应数据和结果视图:从环境搭建到实战全解析
大数据·数据库·mysql
likuolei10 小时前
XQuery 完整语法速查表(2025 最新版,XQuery 3.1)
xml·java·数据库
用户849137175471610 小时前
生产级故障排查实战:从制造 OOM 到 IDEA Profiler 深度破案
java·jvm