当前位置: 首页 > news >正文

使用数据库实现增删改查

 

#include<myhead.h>//定义添加数据函数int do_add(sqlite3 *ppDb)
{//1.准备sql语句,输入要添加的信息int add_numb;          //工号char  add_name[20];    //姓名char  add_sex[10];     //性别double add_score;      //工资printf("请输入要添加的工号:");scanf("%d",&add_numb);printf("请输入要添加的姓名:");scanf("%s",add_name);printf("请输入要添加的性别:");scanf("%s", add_sex);printf("请输入要添加的工资:");scanf("%lf", &add_score);getchar();//准备sql语句char sql[128]="";sprintf(sql,"insert into Worker(numb, name, sex, score) value(%d,\"%s\",\"%s\",%2lf);",add_numb,add_name,add_sex,add_score);//2.定义错误信息存放指针char *errmsg = NULL;//3.执行语句if(sqlite3_exec(ppDb, sql, NULL,NULL,NULL, &errmsg) != SQLITE_OK){printf("exec error:%s\n",errmsg);sqlite3_free(errmsg);errmsg = NULL;return -1;}printf("do_add success\n");return 0;
}//删除员工信息
int do_delete(sqlite3 *ppDb)
{//1.准备sql语句 输入要删除员工信息int delete_numb;printf("请输入要删除记录的工号:");scanf("%d",&delete_numb);getchar();char sql[128]="";sprintff(sql,"delete from Stu where numb=%d",delete_numb);//2.定义错误信息存放指针char *errmsg = NULL;//3.执行语句if(sqlite3_exec(ppDb, sql, NULL,NULL,NULL, &errmsg) != SQLITE_OK){printf("exec error:%s\n",errmsg);sqlite3_free(errmsg);errmsg = NULL;return -1;}printf("do_delete success\n");return 0;}int main(int argc, const char *argv[])
{//定义数据库句柄指针sqlite3 * ppDb = NULL;//打开数据库,如果数据库不存在,则创建数据库//将数据库句柄由参数2返回if(sqlite3_open("./my.db", &ppDb) != SQLITE_OK){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 *sql = "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=======XXX公司员工管理系统=======\n");printf("\t\t======1、添加员工信息=========\n");printf("\t\t======2、删除员工信息=========\n");printf("\t\t======3、修改员工信息=========\n");printf("\t\t======4、查询员工信息=========\n");printf("\t\t======0、退出=========\n");printf("请输入操作码:");          //提示并输入信息scanf("%d", &menu);getchar();                          //吸收回车switch(menu){case 1:{do_add(ppDb);}break;case 2:{do_delete(ppDb);}break;case 3:{//do_update(ppDb);}break;case 4:{//do_search(ppDb);}break;case 0:goto END;default:printf("您输入的功能有误,请重新输入!!!\n");}printf("请输入任意键,按回车清屏\n");while(getchar() != '\n');}END://关闭数据库sqlite3_close(ppDb);return 0;
}

相关文章:

  • JavaSE(上)-Day1
  • typedef的详细使用例子
  • C++_构造函数——构造函数里是否用this指针?
  • 2024年【道路运输企业主要负责人】考试及道路运输企业主要负责人考试报名
  • 一. Ubuntu入门
  • 2024 年 AI 辅助研发趋势:从研发数字化到 AI + 开发工具 2.0,不止于 Copilot
  • ranger的使用
  • 设计模式(十五)状态模式
  • Flask基于配置文件添加项目config配置
  • Selenium 4.0+ 版本的“正确使用”以及“驱动程序的正确安装”
  • TinyEMU编译与使用
  • 二分以及练习题目
  • wordpress外贸独立站
  • laravel-admin 头部添加操作
  • openssl3.2 - exp - 产生随机数
  • [数据结构]链表的实现在PHP中
  • 【刷算法】求1+2+3+...+n
  • 230. Kth Smallest Element in a BST
  • AngularJS指令开发(1)——参数详解
  • Cumulo 的 ClojureScript 模块已经成型
  • extjs4学习之配置
  • HTTP 简介
  • iOS小技巧之UIImagePickerController实现头像选择
  • JSDuck 与 AngularJS 融合技巧
  • JS笔记四:作用域、变量(函数)提升
  • macOS 中 shell 创建文件夹及文件并 VS Code 打开
  • mysql中InnoDB引擎中页的概念
  • passportjs 源码分析
  • React-生命周期杂记
  • 从零开始的无人驾驶 1
  • 让你成为前端,后端或全栈开发程序员的进阶指南,一门学到老的技术
  • 人脸识别最新开发经验demo
  • 一道面试题引发的“血案”
  • 移动互联网+智能运营体系搭建=你家有金矿啊!
  • 在weex里面使用chart图表
  • 怎样选择前端框架
  • 正则学习笔记
  • 如何用纯 CSS 创作一个菱形 loader 动画
  • ​LeetCode解法汇总2808. 使循环数组所有元素相等的最少秒数
  • ​如何使用ArcGIS Pro制作渐变河流效果
  • ###C语言程序设计-----C语言学习(3)#
  • (1)Android开发优化---------UI优化
  • (Redis使用系列) Springboot 实现Redis 同数据源动态切换db 八
  • (八)光盘的挂载与解挂、挂载CentOS镜像、rpm安装软件详细学习笔记
  • (分享)一个图片添加水印的小demo的页面,可自定义样式
  • (含react-draggable库以及相关BUG如何解决)固定在左上方某盒子内(如按钮)添加可拖动功能,使用react hook语法实现
  • (简单) HDU 2612 Find a way,BFS。
  • (七)Java对象在Hibernate持久化层的状态
  • (三)elasticsearch 源码之启动流程分析
  • (十二)springboot实战——SSE服务推送事件案例实现
  • (四)搭建容器云管理平台笔记—安装ETCD(不使用证书)
  • (一)Mocha源码阅读: 项目结构及命令行启动
  • (转) Face-Resources
  • (转)EXC_BREAKPOINT僵尸错误
  • (转)Java socket中关闭IO流后,发生什么事?(以关闭输出流为例) .