网络编程day7

2024-05-24 22:28
文章标签 编程 网络 day7

本文主要是介绍网络编程day7,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

思维导图

数据库编程实现学生管理系统

#include <header.h>
#define ID 1
#define NAME 2
#define AGE 3
#define SCORE 4
int do_add(sqlite3 *ppdb)
{int add_numb;char add_name[20];int add_age;double add_score;printf("enter student id:");scanf("%d",&add_numb);printf("enter student name:");scanf("%s",add_name);printf("enter student age:");scanf("%d",&add_age);printf("enter student score:");scanf("%lf",&add_score);getchar();char sql[128]="";snprintf(sql,sizeof(sql),"insert into stu values(%d,\"%s\",%d,%.2lf);",add_numb,add_name,add_age,add_score);char *errmsg=NULL;if(sqlite3_exec(ppdb,sql,NULL,NULL,&errmsg)!=SQLITE_OK){printf("stu create fail:%s\n",errmsg);sqlite3_free(errmsg);return 1;}printf("table stu create success\n");return 0;
}
int callback(void* arg,int cols,char** col_text,char** col_name)
{if(*(int *)arg==0){for(int i=0;i<cols;i++){printf("%s\t",col_name[i]);}printf("\n");*(int *)arg=1;}for(int i=0;i<cols;i++){printf("%s\t",col_text[i]);}printf("\n");return 0;
}
int do_select(sqlite3 *ppdb)
{int flag=0;char sql[128]="select * from stu;";char *errmsg=NULL;if(sqlite3_exec(ppdb,sql,callback,&flag,&errmsg)!=SQLITE_OK){printf("stu select fail:%s\n",errmsg);sqlite3_free(errmsg);return 1;}printf("select have done\n");return 0;
}
int do_select_2(sqlite3 *ppdb)
{char sql[128]="select * from stu;";char **pazresult=NULL;int cols=0;int rows=0;char *errmsg=NULL;if(sqlite3_get_table(ppdb,sql,&pazresult,&rows,&cols,&errmsg)!=SQLITE_OK){printf("stu select fail:%s\n",errmsg);sqlite3_free(errmsg);return 1;}for(int i=0;i<rows+1;i++){for(int j=0;j<cols;j++){printf("%s\t",pazresult[i*cols+j]);}printf("\n");}sqlite3_free_table(pazresult);return 0;
}
int do_delete(sqlite3 *ppdb)
{int id;printf("enter the student id u want to delete:");scanf("%d",&id);getchar();char sql[128]="";char *errmsg=NULL;snprintf(sql,sizeof(sql),"delete from stu where id=%d;",id);if(sqlite3_exec(ppdb,sql,NULL,NULL,&errmsg)!=SQLITE_OK){printf("stu delete fail:%s\n",errmsg);sqlite3_free(errmsg);return 1;}printf("delete have done\n");return 0;
}
int do_update(sqlite3 *ppdb)
{int id;int newid;char name[20];int age;double score;int column;printf("enter the id u want to update:");scanf("%d",&id);getchar();char sql[128]="";char *errmsg=NULL;printf("enter the column u want to update:");scanf("%d",&column);getchar();switch(column){case 1:{printf("enter the new id:");scanf("%d",&newid);getchar();snprintf(sql,sizeof(sql),"update stu set id = %d where id = %d;",newid,id);if(sqlite3_exec(ppdb,sql,NULL,NULL,&errmsg)!=SQLITE_OK){printf("stu update fail:%s\n",errmsg);sqlite3_free(errmsg);return 1;}printf("update have done\n");}break;case 2:{printf("enter the new name:");scanf("%s",name);getchar();snprintf(sql,sizeof(sql),"update  stu set name = \"%s\" where id = %d ;",name,id);if(sqlite3_exec(ppdb,sql,NULL,NULL,&errmsg)!=SQLITE_OK){printf("stu update fail:%s\n",errmsg);sqlite3_free(errmsg);return 1;}printf("update have done\n");}break;case 3: 		{printf("enter the new age:");scanf("%d",&age);getchar();snprintf(sql,sizeof(sql),"update  stu set age = %d where id = %d;",age,id);if(sqlite3_exec(ppdb,sql,NULL,NULL,&errmsg)!=SQLITE_OK){printf("stu update fail:%s\n",errmsg);sqlite3_free(errmsg);return 1;}printf("update have done\n");}break;case 4:{printf("enter the new score:");scanf("%lf",&score);getchar();snprintf(sql,sizeof(sql),"update stu set score = %.2lf  where id = %d;",score,id);if(sqlite3_exec(ppdb,sql,NULL,NULL,&errmsg)!=SQLITE_OK){printf("stu update fail:%s\n",errmsg);sqlite3_free(errmsg);return 1;}printf("update have done\n");}break;default:printf("argument error\n");break;}return 0;
}int main(int argc, const char *argv[])
{sqlite3 *ppdb=NULL;if(sqlite3_open("02.db",&ppdb)!=SQLITE_OK){printf("open error:%d,%s\n",sqlite3_errcode(ppdb),sqlite3_errmsg(ppdb));return 1;}printf("the sqlite has been opened\n");char sql[128]="create table if not exists stu(id int,name text,age int,score real);";char *errmsg=NULL;if(sqlite3_exec(ppdb,sql,NULL,NULL,&errmsg)!=SQLITE_OK){printf("stu create fail:%s\n",errmsg);sqlite3_free(errmsg);return 1;}printf("table stu create success\n");int menu=0;while(1){system("clear");printf("\t\t========student information mange system===========\n");printf("\t\t=============   1.add  ================\n");printf("\t\t=============  2.delete ================\n");printf("\t\t=============  3.update   ================\n");printf("\t\t=============  4.select  ================\n");printf("\t\t=============   5.exit     ================\n");printf("enter ur choice:");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_select(ppdb);do_select_2(ppdb);}break;case 5:goto END;default:printf("error argument\n");}printf("enter \"enter\" to clear the scream\n");while(getchar()!='\n');}
END:sqlite3_close(ppdb);return 0;
}

这篇关于网络编程day7的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Linux系统配置NAT网络模式的详细步骤(附图文)

《Linux系统配置NAT网络模式的详细步骤(附图文)》本文详细指导如何在VMware环境下配置NAT网络模式,包括设置主机和虚拟机的IP地址、网关,以及针对Linux和Windows系统的具体步骤,... 目录一、配置NAT网络模式二、设置虚拟机交换机网关2.1 打开虚拟机2.2 管理员授权2.3 设置子

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

Linux系统之主机网络配置方式

《Linux系统之主机网络配置方式》:本文主要介绍Linux系统之主机网络配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、查看主机的网络参数1、查看主机名2、查看IP地址3、查看网关4、查看DNS二、配置网卡1、修改网卡配置文件2、nmcli工具【通用

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言