3.6作业

news2024/11/26 10:30:13

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

程序代码:

#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.coloradmin.cn/o/1494076.html

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

相关文章

移动开发:图像查看器

一、新建ImageViewer模块&#xff0c;添加p1-p9图片(注意mdpi后缀) 二、相关代码 1.MainActivity.java文件代码 package com.example.imageviewer;import androidx.appcompat.app.AppCompatActivity;import android.os.Bundle; import android.view.MotionEvent; import and…

Jacob使用教程--通过宏来寻找变量名

说明: 这里做个随比,参考资料请见前面的系列文章 问题展示: 对于一个操作,当我们不知道怎么利用jacob写代码时,而且网上也找不到,可以按照如下操作: 比如,我们要删除 word中的文本框 我们根本不知道文本框,这个变量叫什么,在Microsoft文档哪个父目录下面, 可以通过…

【MySQL】事务?隔离级别?锁?详解MySQL并发控制机制

目录 1.先理清一下概念 2.锁 2.1.分类 2.2.表锁 2.3.行锁&#xff08;MVCC&#xff09; 2.4.间隙锁 2.5.行锁变表锁 2.6.强制锁行 1.先理清一下概念 所谓并发控制指的是在对数据库进行并发操作时如何保证数据的一致性和正确性。在数据库中与并发控制相关的概念有如下几…

测试遍历1e5,1e8数组耗时

1e8大概0.38秒&#xff0c;即380ms 1e5耗时1ms左右&#xff1a; 代码使用方式来自&#xff1a;clock - C Reference (cplusplus.com)

MicroPython ADX51x读取ID和ADC值

from machine import Pin, SoftSPI import timedef ID(agreement):#txbuf 需要将16进制转换为10进制rxbuf bytearray(3) # create a bufferspi SoftSPI(baudrate200000, polarity1, phase0, mosiPin(16), misoPin(4), sckPin(2))spi.init(baudrate125000) # set the bau…

【前端系列】vue

这里写目录标题 一、Vue简介1.1 主流前端框架/库简介 二、下载和安装Vue2.1 下载2.2 安装完成后&#xff0c;检查2.3创建全局安装目录和缓存日志目录2.4 为了下载包快速&#xff0c;改源为淘宝镜像2.5 查看npm配置修改是否成功 三、配置环境变量环境变量—用户变量—选中Path—…

(C语言)深入理解指针1基础

指针是C语言中的一个难点&#xff0c;但如果真正理解了指针&#xff0c;其实没有很难&#xff0c;本篇文章介绍了指针的基础知识&#xff0c;后面还会继续更行指针的内容。感谢支持。 目录 1. 内存和地址 1.1 内存 1.2 究竟该如何理解编址 2. 指针变量和地址 2.1 取地址操…

Midjourney是个什么软件?midjourney订阅教程

数字时代&#xff0c;AI的应用正在不断推动各个领域的发展。其中&#xff0c;AI在艺术和设计领域的运用引起了广泛的关注。作为一款爆火的AI绘画软件&#xff0c;Midjourney通过其独特的原理和便捷的使用方法&#xff0c;为创作者提供了一个创作逼真绘画作品的全新平台 1、AI绘…

初阶数据结构:二叉树

目录 1. 树的相关概念1.1 简述&#xff1a;树1.2 树的概念补充 2. 二叉树2.1 二叉树的概念2.2 二叉树的性质2.3 二叉树的存储结构与堆2.3.1 存储结构2.3.2 堆的概念2.3.3 堆的实现2.3.3.1 堆的向上调整法2.3.3.2 堆的向下调整算法2.3.3.3 堆的实现 1. 树的相关概念 1.1 简述&a…

Java多线程——信号量Semaphore是啥

目录 引出信号量Semaphore &#xff1f;Redis冲冲冲——缓存三兄弟&#xff1a;缓存击穿、穿透、雪崩缓存击穿缓存穿透缓存雪崩 总结 引出 Java多线程——信号量Semaphore是啥 信号量Semaphore &#xff1f; Semaphore 通常我们叫它信号量&#xff0c; 可以用来控制同时访问特…

Day36 网络概述、IP划分、网络模型

文章目录 网络发展史局域网和广域网局域网&#xff08;LAN&#xff09;广域网&#xff08;Wan&#xff09; 光猫路由器 IP地址基本概念地址划分特殊地址&#xff08;后续编程使用&#xff09;IP地址转换端口字节序 网络模型网络模型OSI模型&#xff08;了解&#xff09;TCP/IP模…

15:Zookeeper高可用集群|分布式消息队列Kafka|搭建高可用Hadoop集群

Zookeeper高可用集群&#xff5c;分布式消息队列Kafka&#xff5c;搭建高可用Hadoop集群 Zookeeper集群Zookeeper角色与特性Zookeeper角色与选举Zookeeper的高可用Zookeeper可伸缩扩展性原理与设计Zookeeper安装zookeeper集群管理 Kafka概述在node节点上搭建3台kafka 高可用Had…

Vue.js+SpringBoot开发高校学院网站

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 学院院系模块2.2 竞赛报名模块2.3 教育教学模块2.4 招生就业模块2.5 实时信息模块 三、系统设计3.1 用例设计3.2 数据库设计3.2.1 学院院系表3.2.2 竞赛报名表3.2.3 教育教学表3.2.4 招生就业表3.2.5 实时信息表 四、系…

循环队列--C语音实现

目录 一、循环队列的特点&#xff1a; 二、普通的队列的缺点&#xff1a; 三、循环队列实现原理&#xff1a; 四、循环队列是实现步骤&#xff1a; 1.循环队列的头文件&#xff1a; 2.循环队列的源文件&#xff1a; 3.注意点&#xff1a; 一、循环队列的特点&#xff1…

灯塔:CSS笔记(1)

CSS&#xff1a;层叠样式表 所谓层叠 即叠加的意思&#xff0c;表示样式可以一层一层的层叠覆盖 css写在style标签中&#xff0c;style标签一般写在head标签里面&#xff0c;title标签下面 <!DOCTYPE html> <html lang"en"> <head><meta cha…

java 从环境变量中获取参数及值

window直接在这设置&#xff1a; linux在/etc/profile文件里存放&#xff1a; export keyvalue 然后立即生效&#xff1a;source /etc/profile 代码获取值这样获取&#xff1a; System.getenv("key");

C++初阶篇----类与对象中卷

目录 引言1. 构造函数1.1概念1.2 特性 2. 析构函数2.1 概念2.2 特性 3. 拷贝构造函数3.1 概念3.2特征 4. 赋值运算符重载4.1 运算符重载4.2 赋值运算符重载4.3 前置和后置重载 5.日期类的实现6.const成员7.取地址及const取地址操作符重载 引言 当一个类既没有成员变量又没有成…

【特征选择】CMA-ES(协方差矩阵适应进化策略)

导 读 当将模型拟合到数据集时&#xff0c;可能需要执行特征选择&#xff1a;由于多种原因&#xff0c;仅保留某些特征子集来拟合模型&#xff0c;而丢弃其余特征具有一定的必要性&#xff0c;如下&#xff1a; 保持模型的可解释性&#xff08;特征太多会使解释变得更加困难&am…

css-解决Flex布局下居中溢出滚动截断问题

css-解决Flex布局下居中溢出滚动截断问题 1.出现的问题2.解决方法2.1 Flex 布局下关键字 safe、unsafe2.2 使用 margin: auto 替代 justify-content: center2.3 额外嵌套一层 1.出现的问题 在页面布局中&#xff0c;我们经常会遇到/使用列表内容水平居中于容器中&#xff0c;一…

Codesys自定义库的帮助文档的美化

文章目录 1.前言2.美化的方式2.1.利用html标签2.2.利用reStructuredText 3.相关说明3.1.使用reStructuredText时&#xff0c;中文注释的问题3.2.将文档需要的图片包含到库中3.3.文档的作用区域 1.前言 当我们在codesys中写好自己的库&#xff0c;并且发布给别人使用时&#xf…