1、用C语言开发小型数据库管理系统代码文库.txt如果有来生,要做一棵树,站成永恒,没有悲哀姿势。一半在土里安详,一半在风里飞扬,一半洒落阴凉,一半沐浴阳光,非常沉默非常骄傲,从不依托从不寻找。#include
2、mber; int Math; int C; int Amount; }st; st record[8]; count num[1]; char filename[10]={"0"}; char filename2[10]={"0"}; int Inputnum[8]; void MainMenu(){ /*主菜单*/ printf("\n\t\t\t\t* * * * * * * * * *\n"); printf("\t\t\t\t* 主菜单
3、 *\n"); printf("\t\t\t\t* 1. 创立新文献 *\n"); printf("\t\t\t\t* 2. 添加记录 *\n"); printf("\t\t\t\t* 3. 删除记录 *\n"); printf("\t\t\t\t* 4. 排序 *\n"); printf("\t\t\t\t* 5. 查询记录 *\n"); printf("\t\t\t\t* 6. 退出 *\n"); printf("\t\t\t\t* * * * * * * * * *\n"
4、); } void DelMenu(){ /*删除菜单*/ printf("\n\t\t\t\t* * * * * * * * * * * *\n"); printf("\t\t\t\t* 删除菜单 *\n"); printf("\t\t\t\t* 1. 学号查询删除 *\n"); printf("\t\t\t\t* 2. 返回到上级菜单 *\n"); printf("\t\t\t\t* * * * * * * * * *
5、 *\n"); } void RankingMenu(){ /*排序菜单*/ printf("\n\t\t\t\t* * * * * * * * * * * *\n"); printf("\t\t\t\t* 排序菜单 *\n"); printf("\t\t\t\t* 1. 数学成绩排序 *\n"); printf("\t\t\t\t* 2. C语言成绩排序 *\n"); printf("\t\t\t\t* 3. 总分排序
6、 *\n"); printf("\t\t\t\t* 4. 返回到上级菜单 *\n"); printf("\t\t\t\t* * * * * * * * * * * *\n"); } void InquireMenu(){ /*查讯菜单*/ printf("\n\t\t\t\t* * * * * * * * * * * *\n"); printf("\t\t\t\t* 查讯菜单 *\n"); printf("\t\t\t\t* 1.
7、 学号查讯 *\n"); printf("\t\t\t\t* 2. 姓名查讯 *\n"); printf("\t\t\t\t* 3. 数学成绩查讯 *\n"); printf("\t\t\t\t* 4. C语言成绩查讯 *\n"); printf("\t\t\t\t* 5. 总分查讯 *\n"); printf("\t\t\t\t* 6. 返回到上级菜单 *\n"); printf("\t\t\t\t* * * * * * * * * * * *\n"); } char In
8、putfilename(){ /*输入文献名同步产生付本文献名*/ char str2[]={"B"}; printf("** 请输入文献名 ** :"); scanf("%s",filename); getchar(); strcpy(filename2,filename); strcat(filename2,str2); } FILE *readfile(){ /*读取文
9、档*/ FILE *fp1; if((fp1=fopen(filename,"rb"))==NULL) {printf("\n文献读取错误!!\n"); fclose(fp1); } return(fp1); } FILE *foundfile(){ /*新建文档*/ FILE *fp1; if((fp1=fopen(filename,"wb"))==NULL) {printf("\n文献创立错误!!\n");
10、 fclose(fp1); } return(fp1); } FILE *savefile(){ /*追加文档*/ FILE *fp1; if((fp1=fopen(filename,"ab"))==NULL) {printf("\n文献追加错误!!\n"); fclose(fp1); } return(fp1); } int InputSave(){
11、 /*添加数据 */ int i=0,j; char ch='y'; while(ch!='w') {i=i+1; printf("\n** 请输入姓名(字符型) ** :"); scanf("%s",record[i].name); Loop1: printf("\n** 请输入学号(长整型) ** :"); scanf("%ld",&record[i].Number); if(i!=1) for(j=1;j
12、j++) if(record[i].Number==record[j].Number) {printf("\n\t警告!输入了二个同样学号!第%d条和第%d学号相似!\n",i,j); printf("\n\t请重新输入!\n"); goto Loop1; } Loop2:printf("\n** 请输入数学成绩(整型) ** :"); scanf("%d",
13、record[i].Math); if(record[i].Math>100||record[i].Math<0) {printf("\n\t输入分数不服合实际规定!请重新录入!\n"); goto Loop2; } Loop3:printf("\n** 请输入C语言成绩(整型) ** :"); scanf("%d",&record[i].C); if(record[i].C>100||record[i].C<0) {printf("\n\t输入分数不服合实际规定!请重新录入!\n");
14、goto Loop3; } record[i].Amount=record[i].Math+record[i].C; printf(" \n'w'=结束录入 's'=重新录入此条记录 'n'=下一条 :"); getchar(); /*吃掉上一种回车符*/ if((ch=getchar())=='s') i=i-1; } return(i); } /* void R
15、eadComputer(int i,FILE *fp1){ (文本方式)数据写入机器 int j; for(j=1;j
16、 (文本方式)数据写到文献中 int j; for(j=1;j
17、 for(j=1;j
18、rd[j],sizeof(struct st),1,fp1))!=1) {printf("\n主文献数据写入错误!\n"); fclose(fp1); } } /* ************************************************************ *********************************************************** */ FILE *readfile2(){ /
19、读文献付本*/ FILE *fp1; if((fp1=fopen(filename2,"rb"))==NULL) {printf("\n付本文献读取错误!\n"); fclose(fp1); } return(fp1); } FILE *foundfile2(){ /*新建文献付本*/ FILE *fp1; if((fp1=fopen(filename2,"wb"))==NULL) {prin
20、tf("\n付本文献创立错误!\n"); fclose(fp1); } return(fp1); } FILE *savefile2(){ /*追加文献付本*/ FILE *fp1; if((fp1=fopen(filename2,"ab"))==NULL) {printf("\n付本文献追加错误!\n"); fclose(fp1); } return(fp1); } /*
21、 void Additive2(int i,FILE *fp1){ 数据与入付本文献(文本方式) int j; char str2={"0"}; if(strcmp(filenameF,str2)!=0) strcpy(num[0].name,filenameF); else strcpy(num[0].name,filenameA); num[0].num=i; fprintf(fp1,"%s,%d",num[0].name,num[0].nu
22、m); } int ReadComputer2(FILE *fp1){ 读出付本中数据(文本方式) int j,k; fscanf(fp1,"%s,%d",num[0].name,&num[0].num); k=num[0].num; return(k); } */ void Additive2Two(int i,FILE *fp1){ /*数据写入付本文献(二进制方式)*/ ch
23、ar str2[]={"0"}; if(strcmp(filename2,str2)!=0) strcpy(num[0].name,filename2); else strcpy(num[0].name,filename2); num[0].num=i; if((fwrite(&num[0],sizeof(struct count),1,fp1))!=1) {printf("\n付本文献数据写入错误!\n"); fclose(fp1); } } int ReadComputer2Tw
24、o(FILE *fp1){ /*读出付本中数据(二进制方式)*/ int j; if((fread(&num[0],sizeof(struct count),1,fp1))!=1) {printf("\n付本文献数据读取错误!\n"); fclose(fp1); } j=num[0].num; return(j); } /* ********************************************************
25、 *********************************************************** */ void Num_inquire(){ /*学号查询*/ int num,j,time; FILE *fp1,*fp2; fp1=readfile(); /*读取文档*/ fp2=readfile2();
26、 /*(开打方式'读'**'引用读文献名')读文献付本*/ time=ReadComputer2Two(fp2); /*读出付本中数据(二进制方式)*/ ReadComputer2(time,fp1); /*(2方式)数据写入机器*/ fclose(fp1);fclose(fp2); printf("输入学号:");
27、 scanf("%ld",&num); /*getchar();*/ for(j=1;j






