1. C語言程序設計 超市商品信息管理系統
假設某超市經營各種商品,每種商品包括以下信息:商品編號、商品名稱、商品品牌、庫存數量、售價、已售數量。系統的主要功能包括:1. 創建商品信息文件:根據提示輸入若干商品的信息,並將信息保存至一個文件中。2. 商品進貨管理:每次購入新商品,需按要求輸入商品所含各項信息並存入商品信息文件中。如果已經存在該商品(以商品編號為准),則修改相應的庫存數量信息,否則生成新的商品信息記錄。3. 商品銷售管理:每次有商品銷售出去,則按要求輸入商品編號和商品名稱信息,並修改相應的商品信息文件。注意:商品銷售時要檢查庫存數量的合法性(即銷售出去的數量必須小於庫存數量)。4. 按不同條件進行查詢操作,輸出滿足條件的商品信息。(1) 輸入商品名稱,在商品信息文件中查找相應的商品信息並輸出。(2) 輸入商品品牌,在商品信息文件中查找該品牌的所有信息並輸出。5. 按不同條件對商品信息進行統計工作。(1) 輸入商品名稱,在商品信息文件中統計該商品的銷售總額。(2) 設置一個庫存數量警戒值,輸出庫存數量小於該警戒值的所有庫存商品的信息。(3) 輸入商品品牌,在商品信息文件中統計其不同商品名稱的庫存量,並輸出庫存量最高的那個商品的信息。
2. C語言編寫的超市管理系統
有一個小型超市,出售N(N>=10)種商品,設計並實現一個系統,完成下列功能:
1. 保存及輸出。超市中的各種商品信息保存在指定文件中,可以把它們輸出顯示。
2. 計算並排序。計算每類商品的總價值(sum,單精度)及平均價(aver,單精度,輸出一位小數),將每類商品按平均價從大到小的順序排序列印出來。
3. 統計。統計輸出庫存量低於100的貨號及類別。統計輸出有兩種以上(含兩種)商品庫存量低於100的商品類別。
1.2總體結構
本程序主要分為八個模塊:主模塊、信息輸出修改模塊、新建信息模塊、排序模塊、計算模塊、統計模塊1、統計模塊2、列印模塊。
1) 主模塊:通過調用各分模塊實現功能;
2) 信息輸出修改模塊:輸出顯示文件中商品信息內容,添加商品信息,刪除商品信息,修改商品信息;
3) 新建商品信息模塊:建立一個新結構體,為鏈表存信息用,並且將信息保存在指定的文件中;
4) 排序模塊:把文件中順序零亂的商品信息按單價的大小從高到低進行排序,放到鏈表裡存儲;
5) 計算模塊:將所有商品的價格與庫存量進行累加求和;
6) 列印模塊:將商品信息按每類平均價格排序(從高到低)按順序列印出來;
7) 統計模塊1:統計庫存量低於100的貨名及類別;
8) 統計模塊2:統計商品庫存量有2種以上(含2種)低於100的商品類別。
附 錄(程序清單)
#include "stdio.h" /*輸入,輸出頭文件*/
#include "stdlib.h" /*申請空間頭文件*/
#include "string.h" /*對字元串加工頭文件*/
#include "conio.h" /*清屏頭文件*/
FILE *fp;
int n=0; /*定義文件指針類型*/
int i,j,a[4],m; /*定義整數類型*/
float aver[4],sum[4],g[4],h; /*定義浮點類型*/
char c[5]="elec"; /*定義字元數組類型*/
char d[5]="comm"; /*定義字元數組類型*/
char e[5]="food"; /*定義字元數組類型*/
char f[5]="offi"; /*定義字元數組類型*/
struct good /*定義結構體*/
{
int num; /*商品編號*/
char name[20]; /*商品名稱*/
char kind[40]; /*商品類型*/
float price; /*商品價格*/
char unit[10]; /*商品單位*/
int quantity; /*商品數量*/
struct good *next; /*定義結構體指針類型*/
}*head,*p1,*p2;
struct good *createlist() /*創建鏈表函數*/
{
struct good *head1,*p1,*p2; /*定義結構體指針類型*/
if((fp=fopen("goods message.txt","w"))==NULL) /*判斷能否打開文件*/
{
printf("can not open the file");
exit(0); /*結束程序*/
}
head1=(struct good *)malloc(sizeof(struct good)); /*申請頭結點空間*/
p1=head1;
p2=head1;
printf("*********************************************\n");
printf("請輸入信息:編號,名稱,類型,價格,單位,數目\n");
printf(" (以輸入「-1」表示結束輸入)\n");
printf("*********************************************\n");
printf("____________________\n");
scanf("%d %s %s %f %s %d",&p1->num,p1->name,p1->kind,&p1->price,p1->unit,&p1->quantity); /*輸入商品信息*/
printf("____________________\n");
p1->next=NULL;
fprintf(fp,"%d %s %s %f %s %d ",p1->num,p1->name,p1->kind,p1->price,p1->unit,p1->quantity); /*將商品信息寫入文件*/
while(1)
{
p1=(struct good *)malloc(sizeof(struct good)); /*申請新空間*/
printf("*********************************************\n");
printf("請輸入信息:編號,名稱,類型,價格,單位,數目\n");
printf(" (以輸入「-1」表示結束輸入)\n");
printf("*********************************************\n");
printf("____________________\n");
scanf("%d",&p1->num);
if(p1->num==-1) /*申請空間結束條件*/
{
printf("____________________\n\n");
fprintf(fp,"%d",-1);
fclose(fp);
return head1; /*返回頭指針*/
}
scanf("%s %s %f %s %d",p1->name,p1->kind,&p1->price,p1->unit,&p1->quantity); /*輸入商品信息*/
printf("________________\n");
fprintf(fp,"%d %s %s %f %s %d ",p1->num,p1->name,p1->kind,p1->price,p1->unit,p1->quantity); /*將商品信息寫入文件*/
p1->next=NULL;
p2->next=p1;
p2=p1;
}
}
struct good *paixu(struct good*head2) /*鏈表排序函數*/
{
struct good *p6,*p7,*r,*s; /*定義結構體指針類型*/
for(i=0;i<=3;i++) /*賦初值值*/
{
a[i]=0;
sum[i]=0;
aver[i]=0;
}
p6=(struct good *)malloc(sizeof(struct good)); /*申請新空間*/
p6->next=head2;
head2=p6;
while(p6->next!=NULL) /*判斷循環結束條件*/
{
p7=p6->next;
r=p6;
while(p7->next!=NULL) /*判斷循環結束條件*/
{
if((p7->next->price)>(r->next->price)) /*判斷是否調換*/
r=p7;
p7=p7->next;
}
if(p6!=r) /*判斷循環結束條件*/
{
s=r->next; /*指針調換*/
r->next=s->next;
s->next=p6->next;
p6->next=s;
}
p6=p6->next;
}
p6=head2;
head2=head2->next;
free(p6); /*釋放第一個無效空間*/
return head2;
}
void jisuan()
{
p1=head;
do
{
if(strcmp(p1->kind,c)==0) /*判斷是否為電器類型*/
{
sum[0]=sum[0]+(p1->price)*(p1->quantity); /*求電器總價*/
a[0]=a[0]+p1->quantity; /*求電器總件數*/
}
if(strcmp(p1->kind,d)==0) /*判斷是否為日用品類型*/
{
sum[1]=sum[1]+(p1->price)*(p1->quantity); /*求日用品總價*/
a[1]=a[1]+p1->quantity; /*求日用品總件數*/
}
if(strcmp(p1->kind,e)==0) /*判斷是否為辦公用品類型*/
{
sum[2]=sum[2]+(p1->price)*(p1->quantity); /*求辦公用品總價*/
a[2]=a[2]+p1->quantity; /*求辦公用品總件數*/
}
if(strcmp(p1->kind,f)==0) /*判斷是否為食品類型*/
{
sum[3]=sum[3]+(p1->price)*(p1->quantity); /*求食品總價*/
a[3]=a[3]+p1->quantity; /*求食品總件數*/
}
p1=p1->next;
}while (p1!=NULL); /*遍歷鏈表結束條件*/
for(i=0;i<4;i++)
aver[i]=sum[i]/a[i]; /*求每類商品平均價*/
printf("****************************************************\n");
printf("商品類型 \t 平均價\t 總庫存量\n");
printf("****************************************************\n");
printf("____________________________________________________\n");
printf("電器總價值:%0.1f\t平均價:%0.1f\t總庫存量:%d\n",sum[0],aver[0],a[0]);
printf("____________________________________________________\n");
printf("日用品總價值:%0.1f\t平均價:%0.1f\t總庫存量:%d\n",sum[1],aver[1],a[1]);
printf("____________________________________________________\n");
printf("食品總價值:%0.1f\t平均價:%0.1f\t總庫存量:%d\n",sum[2],aver[2],a[2]);
printf("____________________________________________________\n");
printf("辦公用品總價值:%0.1f\t平均價:%0.1f\t總庫存量:%d\n",sum[3],aver[3],a[3]);
printf("____________________________________________________\n");
}
void shuchu() /*輸出商品信息函數*/
{
do
{
struct good *p3,*p4,*p5; /*定義結構體指針類型*/
int n=0,p=0,q=0,r=0;
printf("所有商品信息:\n");
printf("編號,名稱,類型,價格,單位,數目\n");
printf("**********************************\n");
if((fp=fopen("goods message.txt","rb+"))==NULL) /*判斷能否打開文件*/
{
printf("can not open the file");
exit(0); /*結束程序*/
}
head=(struct good *)malloc(sizeof(struct good)); /*申請頭結點空間*/
p3=head;
fscanf(fp,"%d %s %s %f %s %d ",&p3->num,p3->name,p3->kind,&p3->price,p3->unit,&p3->quantity); /*從文件中寫到鏈表*/
while(1)
{
p4=(struct good *)malloc(sizeof(struct good)); /*申請頭結點空間*/
fscanf(fp,"%d ",&p4->num);
if(p4->num!=-1) /*判斷循環結束條件*/
{
fscanf(fp,"%s %s %f %s %d ",p4->name,p4->kind,&p4->price,p4->unit,&p4->quantity); /*從文件中寫到鏈表*/
p4->next=NULL;
p3->next=p4;
p3=p4;
}
else
{
p3->next=NULL;
break;
}
}
fclose(fp); /*關閉文件*/
p3=head;
while(p3!=NULL)
{
printf(" %d %s %s %0.1f %s %d\n\n",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity);
printf("__________________________________\n");
p3=p3->next;
}
printf("**********************************\n");
printf("//////////////////////////////////\n");
while(n!=4)
{
p3=head;
printf("**********************************\n");
printf("1 添加商品信息\n");
printf("2 刪除某商品信息\n");
printf("3 修改某商品信息\n");
printf("4 返回(當你完成了對某一商品的添加、刪除或者修改後請按4返回)\n");
printf("**********************************\n");
scanf("%d",&n);
if(n==1) /*添加商品信息*/
{
printf("請輸入商品 編號 名稱 類型 價格 單位 數目\n");
printf("**********************************\n");
p4=(struct good *)malloc(sizeof(struct good)); /*申請空間*/
scanf("%d %s %s %f %s %d",&p4->num,p4->name,p4->kind,&p4->price,p4->unit,&p4->quantity); /*輸入商品信息*/
p4->next=NULL;
while(p3->next!=NULL) /*判斷循環結束條件*/
{
p3=p3->next;
}
p3->next=p4;
p3=head;
if((fp=fopen("goods message.txt","w"))==NULL) /*判斷能否打開文件*/
{
printf("can not open the file");
exit(0); /*結束程序*/
}
while(p3!=NULL)
{
fprintf(fp,"%d %s %s %f %s %d ",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity) /*將商品信息寫入文件*/
p3=p3->next;
}
fprintf(fp,"%d",-1);
fclose(fp); /*關閉文件*/
printf("**********************************\n");
printf("__________________________________\n");
printf("------------請按4返回-------------\n");
printf("__________________________________\n");
printf("**********************************\n");
}
if(n==2) /*刪除商品*/
{
printf("**********************************\n");
printf("請輸入需要刪除的商品編號\n");
printf("**********************************\n");
scanf("%d",&p);
printf("**********\n");
printf("1 確認刪除\n2 取消刪除\n");
printf("**********\n");
scanf("%d",&r);
if(r==1)
{
if((head->num)==p)
{
head=head->next;
free(p3); /*釋放空間*/
}
else
{
p4=head;
p3=p4->next;
while(p3!=NULL) /*判斷循環結束條件*/
{
if((p3->num)==p)
{
p5=p3->next;
free(p3); /*釋放空間*/
p4->next=p5;
break;
}
p3=p3->next;
p4=p4->next;
}
}
if((fp=fopen("goods message.txt","w"))==NULL) /*判斷能否打開文件*/
{
printf("can not open the file");
exit(0); /*結束程序*/
}
p3=head;
while(p3!=NULL) /*判斷循環結束條件*/
{
fprintf(fp,"%d %s %s %f %s %d ",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*將商品信息寫入文件*/
p3=p3->next;
}
fprintf(fp,"%d",-1);
fclose(fp); /*關閉文件*/
}
if(r==2)
continue; /*繼續循環*/
printf("**********************************\n");
printf("__________________________________\n");
printf("------------請按4返回-------------\n");
printf("__________________________________\n");
printf("**********************************\n");
}
if(n==3) /*修改某商品信息*/
{
printf("請輸入需要修改的商品編號\n");
scanf("%d",&q);
while(p3!=NULL) /*判斷循環結束條件*/
{
if((p3->num)==q) /*判斷是否為所需要修改的商品*/
{
printf("請輸入商品單價與庫存量(如果單價不變請輸入原來的單價)\n");
scanf("%f %d",&p3->price,&p3->quantity); /*輸入商品價格與庫存量*/
}
p3=p3->next;
}
if((fp=fopen("goods message.txt","w"))==NULL) /*判斷能否打開文件*/
{
printf("can not open the file");
exit(0); /*結束程序*/
}
p3=head;
while(p3!=NULL) /*判斷循環結束條件*/
{
fprintf(fp,"%d %s %s %f %s %d ",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*將商品信息寫入文件*/
p3=p3->next;
}
fprintf(fp,"%d",-1);
fclose(fp); /*關閉文件*/
printf("**********************************\n");
printf("__________________________________\n");
printf("------------請按4返回-------------\n");
printf("__________________________________\n");
printf("**********************************\n");
}
if(n==4) /*退出*/
break;
}
printf("**********\n");
printf("1 繼續修改\n---------\n2 返回\n");
printf("**********\n");
scanf("%d",&p);
if(p==1)
continue; /*繼續循環*/
if(p==2)
break; /*跳出循環*/
}while(n!=2);
fclose(fp); /*關閉文件*/
}
void printf0(struct good *p) /*遍歷鏈表並列印電器類商品函數*/
{
struct good *p3; /*定義結構體指針類型*/
p3=p;
while (p3!=NULL) /*判斷遍歷鏈表循環結束條件*/
{
if(strcmp(p3->kind,c)==0) /*判斷商品類型是否為電器類型*/
{
printf("%d\t%s\t%s\t%0.1f\t%s\t%d\n",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*輸出電器類商品信息*/
printf("________________________________________________\n");
}
p3=p3->next;
}
return;
}
void printf1(struct good *p) /*遍歷鏈表並列印日用品類商品函數*/
{
struct good *p3; /*定義結構體指針類型*/
p3=p;
while (p3!=NULL) /*判斷遍歷鏈表循環結束條件*/
{
if(strcmp(p3->kind,d)==0) /*判斷商品類型是否為日用品類型*/
{
printf("%d\t%s\t%s\t%0.1f\t%s\t%d\n",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*輸出日用品類商品信息*/
printf("________________________________________________\n");
}
p3=p3->next;
}
return;
}
void printf2(struct good *p) /*遍歷鏈表並列印辦公用品類商品函數*/
{
struct good *p3; /*定義結構體指針類型*/
p3=p;
while (p3!=NULL) /*判斷遍歷鏈表循環結束條件*/
{
if(strcmp(p3->kind,e)==0) /*判斷商品類型是否為辦公用品類型*/
{
printf("%d\t%s\t%s\t%0.1f\t%s\t%d\n",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*輸出辦公用品類商品信息*/
printf("________________________________________________\n");
}
p3=p3->next;
}
return;
}
void printf3(struct good *p) /*遍歷鏈表並列印食品類商品函數*/
{
struct good *p3; /*定義結構體指針類型*/
p3=p;
while (p3!=NULL) /*判斷遍歷鏈表循環結束條件*/
{
if(strcmp(p3->kind,f)==0) /*判斷商品類型是否為食品類型*/
{
printf("%d\t%s\t%s\t%0.1f\t%s\t%d\n",p3->num,p3->name,p3->kind,p3->price,p3->unit,p3->quantity); /*輸出食品類商品信息*/
printf("________________________________________________\n");
}
p3=p3->next;
}
return;
}
void shunxudayin()
{
for(i=0;i<4;i++)
g[i]=aver[i]; /*將平均價賦給新數組*/
for(j=0;j<3;j++) /*將新數組用冒泡排序法排序*/
for(i=j+1;i<4;i++)
{
if(g[j]<g[i])
{
h=g[j];
g[j]=g[i];
g[i]=h;
}
}
printf("\n****************************\n");
printf("商品平均價格排序表(從高到低)\n");
printf("****************************\n");
printf("________________________________________________\n");
printf("編號\t名稱\t類別\t單價\t單位\t數量\n");
printf("________________________________________________\n");
for(j=0;j<4;j++)
for(i=0;i<4;i++)
{
if (aver[i]==g[j]) /*判斷每類商品平均價格的先後順序*/
switch(i)
{
case 0:
printf0(head); /*調用遍歷鏈表並列印電器類商品函數*/
break;
case 1:
printf1(head); /*調用遍歷鏈表並列印日用品類商品函數*/
break;
case 2:
printf2(head);/*調用遍歷鏈表並列印辦公用品類商品函數*/
break;
case 3:
printf3(head); /*調用遍歷鏈表並列印食品類商品函數*/
break;
}
}
}
void tongji1()
{
p1=head;
printf("\n************************\n");
printf("庫存量低於100的貨名及類別\n");
printf("************************\n");
printf("________________________\n");
printf("商品名稱\t商品類型\n");
printf("________________________\n");
while(p1!=NULL) /*判斷遍歷鏈表循環結束條件*/
{
if(p1->quantity<100) /*判斷庫存量是否小於100*/
{
printf("%s\t%s\n",p1->name,p1->kind); /*輸出商品名稱及類別*/
printf("________________________\n");
}
p1=p1->next;
}
}
void tongji2()
{
printf("\n**********************************************\n");
printf("商品庫存量有2種以上(含2種)低於100的商品類別:\n");
printf("**********************************************\n");
printf("________\n");
if((a[0]<100)&&(a[0]>=2)) /*判斷電器類庫存量是否為2種以上(含2種)低於100*/
{
printf("電器\n");
printf("________\n");
}
if((a[1]<100)&&(a[1]>=2)) /*判斷日用品類庫存量是否為2種以上(含2種)低於100*/
{
printf("日用品\n");
printf("________\n");
}
if((a[2]<100)&&(a[2]>=2)) /*判斷食品類庫存量是否為2種以上(含2種)低於100*/
{
printf("食品\n");
printf("________\n");
}
if((a[3]<100)&&(a[3]>=2)) /*判斷辦公用品類庫存量是否為2種以上(含2種)低於100*/
{
printf("辦公用品\n");
printf("________\n");
}
}
int main(int argc, char* argv[])
{
struct good *p1,*p2; /*定義結構體指針類型*/
while(1)
{
printf("***********************************************\n");
printf("1 ----------輸出查看或者修改已存信息-----------\n");
printf("-----------------------------------------------\n");
printf("2 -----重新輸入新信息(並且刪除原有信息)------\n");
printf("-----------------------------------------------\n");
printf("3 統計商品信息(如果您還沒有查看過信息請先按1)\n");
printf("-----------------------------------------------\n");
printf("4 -------------------退出---------------------\n");
printf("***********************************************\n");
scanf("%d",&m);
if(m==1)
shuchu(); /*調用輸出信息函數*/
if(m==2)
{
system("cls");
head=createlist(); /*調用建立鏈表函數*/
}
if(m==3)
{
printf("統計結果如下\n");
head=paixu(head); /*調用鏈表排序函數*/
jisuan(); /*調用計算函數*/
shunxudayin(); /*調用順序列印函數*/
tongji1(); /*調用統計1函數*/
tongji2(); /*調用統計2函數*/
}
if(m==4)
{
p1=head;
while(p1!=NULL) /*判斷遍歷鏈表結束條件*/
{
p2=p1->next;
free(p1); /*釋放空間*/
p1=p2;
}
break;
}
}
return 0; /*結束程序*/
}
3. 商品庫存管理系統的c語言源代碼
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
struct BOOK
{
int id,usr[10],total,store,days[10];
char name[31],author[21];
}books[100];
/*上面是結構體的定義,用於存放書籍及借書的信息。*/
void page_title(char *menu_item)
{
clrscr();
printf(">>> 圖 書 管 理 系 統 <<<\n\n- %s -\n\n",menu_item);
}
/*上面是列印頁眉的函數,同時通過參數menu_item,可以顯示當前的狀態。*/
void return_confirm(void)
{
printf("\n按任意鍵返回……\n");
getch();
}
/*上面是返回前請求確認的函數,以便在返回前觀察結果*/
int search_book(void)
{
int n,i;
printf("請輸入圖書序號:");
scanf("%d",&i);
for(n=0;n<100;n++)
{
if(books[n].id==i)
{
printf("書名:%s\n",books[n].name);
printf("作者:%s\n",books[n].author);
printf("存數:%d of ",books[n].store);
printf("%d\n",books[n].total);
return n;
}
}
printf("\n輸入錯誤或無效圖書序號.\n");
return -1;
}
/*上面的函數是在數組中找到圖書號匹配的記錄,顯示其信息並返
回數組下標,如果找不到相應記錄則提示錯誤並返回-1。*/
void book_out(void)
{
int n,s,l,d;
page_title("借閱圖書");
if((n=search_book())!=-1&&books[n].store>0)
{
printf("請輸入借書證序號:");
scanf("%d",&s);
printf("請輸入可借天數:");
scanf("%d",&d);
for(l=0;l<10;l++)
{
if(books[n].usr[l]==0)
{
books[n].usr[l]=s;
books[n].days[l]=d;
break;
}
}
books[n].store--;
}
if(n!=-1&&books[n].store==0) printf("此書已經全部借出.\n");
return_confirm();
}
/*上面是借書的函數,首先調用找書函數*/
void book_in(void)
{
int n,s,l;
page_title("歸還圖書");
if((n=search_book())!=-1&&books[n].store<books[n].total)
{
printf("借閱者圖書證列表:\n");
for(l=0;l<10;l++)
if (books[n].usr[l]!=0)
printf("[%d] - %d天\n",books[n].usr[l],books[n].days[l]);
printf("請輸入借書證序號:");
scanf("%d",&s);
for(l=0;l<10;l++)
{
if(books[n].usr[l]==s)
{
books[n].usr[l]=0;
books[n].days[l]=0;
break;
}
}
books[n].store++;
}
if(n!=-1&&books[n].store==books[n].total)
printf("全部入藏.\n");
return_confirm();
}
void book_add(void)
{
int n;
page_title("注冊新書");
for(n=0;n<100;n++)
if(books[n].id==0) break;
printf("序號:");
scanf("%d",&books[n].id);
4. 跪求一個小型超市管理系統,用java編寫的,急~ 只要源代碼。。可以發我郵箱
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class Conn {
private static final String driver="com.mysql.jdbc.Driver";
private static final String url="jdbc:mysql://localhost:3306/blog?user=root&password=root";
//獲得資料庫連接
public static Connection getConnection(){
Connection conn = null;
try {
Class.forName(driver);
conn = DriverManager.getConnection(url);
if(conn != null){
System.out.print("成功");
}
} catch (SQLException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
return conn;
}
//關閉Resultset
public static void closeResultSet(ResultSet rs)
{
try
{
if(rs != null)
{
rs.close();
}
}catch (SQLException ex)
{
ex.printStackTrace();
}
}
//關閉Statement
public static void closeStatement(Statement st)
{
try
{
if(st != null)
{
st.close();
}
}catch (SQLException ex)
{
ex.printStackTrace();
}
}
//關閉Connection
public static void closeConnection(Connection conn)
{
try
{
if(conn != null)
{
conn.close();
}
}catch (SQLException ex)
{
ex.printStackTrace();
}
}
//測試資料庫連接是否成功
public static void main(String[] args) {
Conn.getConnection();
}
}
5. C語言設計商品管理系統,可以實現商品的錄入,查詢,求源代碼
#include <stdio.h>
#include <conio.h>
#include <string.h>
#define SIZE 300
typedef struct
{
char name[30];
int num;
char shang[10];
float price;
}record;
void DataInput(record *com, int *nptr);
int DataRead(record *com,int *nptr) ;
void DataStorage(record *com, int n); /*信息保存到文件*/
void DataFind( );
void DataDisPlay( );
void DataAdd( );
void DataDel( );
void DataStatistic( );
int main( )
{
record shangpin[SIZE];
int number=20; /*設商品數*/
char fn;
printf("\t~~~~~~商品管理系統~~~~~~");
while(1)
{
printf("\n\t\t1.商品信息錄入\n"); /*顯示主菜單*/
printf("\t\t2.商品信息顯示\n");
printf("\t\t3.商品信息查找\n");
printf("\t\t4.商品信息添加\n");
printf("\t\t5.商品信息刪除\n");
printf("\t\t6.商品信息統計\n");
printf("\t\t0.退出系統");
printf("\n\t~~~~~~~~~~~~~~~~\n");
printf("\t請輸入你的一個選項(數字0-6): ");
fflush(stdin);
scanf("%c",&fn);
puts("\n");
switch(fn) /*切換到不同功能*/
{
case '1':
DataInput(shangpin, &number );
break; /*錄入信息*/
case '2':DataDisPlay();
break; /*信息顯示*/
case '3':
DataFind();
break; /*信息查找*/
case '4':
DataAdd( );
break; /*增加*/
case '5':
DataDel( );
break; /*刪除*/
case '6':
DataStatistic();
break; /*信息統計*/
case '0':
return 0;
default:puts("\t\t沒有這個項!返回主菜單!");
break;
}
printf("\n\t\t完畢!按任意鍵繼續");
getch( );
puts("\n");
}
}
void DataInput(record *com, int *nptr) /*商品信息錄入*/
{
int i = 0;
int n ; /*錄入的總數*/
char YesOrNo; /*判斷是否保存*/
char shangming[30]; /*商名*/
int haoma; /*商品號*/
char shangjia[10]; /*單價*/
float danjia;
printf("\t\t請輸入商品個數:");
scanf("%d",&n);
*nptr = n; /*nptr返回商品個數*/
printf("\t\t現在開始錄入這%d個商品信息:\n\n",n);
while(i<n)
{
printf("請輸入商品的商品名:",i+1);
scanf("%s",&shangming);
printf("請輸入商品的商品號:",i+1);
scanf("%d",&haoma);
printf("請輸入商品的生產商:",i+1);
scanf("%s",&shangjia);
printf("請輸入商品的單價 :",i+1);
scanf("%f",&danjia);
if(danjia>=0&&danjia<=1000) /*有效的單價才錄入*/
{
strcpy(com[i].name,shangming);
com[i].num = haoma;
strcpy(com[i].shang,shangjia);
com[i].price = danjia;
i =i+1;
}
else
printf("輸入的單價是一個無效的值!!!\n\n");
} /*結束while*/
printf("要保存您剛才錄入的數據嗎(Y/N)?"); /*選擇保存*/
fflush(stdin);
scanf("%c",&YesOrNo);
if(YesOrNo=='y'||YesOrNo=='Y')
DataStorage(com,n);
else if(YesOrNo=='n'||YesOrNo=='N')
return;
else
printf("輸入了不正確的選項\n");
return;
} /*結束函數*/
void DataFind( ) /*查找*/
{
void OnNumber(record *com,int n ); /*按商品號排序*/
int key; /*key為要查找的關鍵值*/
int low = 0; /*下限*/
int high ; /*上限*/
int mid ; /*中間值*/
char ans; /*選項*/
record com[SIZE];
int n;
if(DataRead(com,&n)==1) /*從文件中讀取信息*/
{
OnNumber(com,n); /*先按商品號排序*/
high = n;
do
{
printf("\n\n\t\t請輸入你要查找的商品號:");
scanf("%d",&key);
low = 0;high = n;
while (low <=high)
{
mid = (high + low)/2; /*折半查找法*/
if (key == com[mid].num )
{
printf("\n\t\t你要找的是第%d個商品\n",mid + 1);
printf("\t\t結果如下:\n\n");
printf("序號\t\t商品名\t 商品號\t生產商\t單價\n");
printf("%3d%17s%12d%12s%8.1f\n",mid+1,com[mid].name,com[mid].num,com[mid].shang,
com[mid].price);
break; /*如果找到則退出循環*/
}
if (key > com[mid].num ) low = mid + 1;
else high = mid - 1;
}
if (low > high)
printf("\t\t,沒有找到這個價格!\n");
printf("\n\t\t還要繼續查詢嗎(Y/N)?");
ans = getch( );
}
while (ans =='Y'||ans == 'y'); /*結束do....while*/
}
}
void DataStorage(record *com, int n) /*錄入保存文件*/
{
int i;
FILE *comPtr;
char FileName[20];
printf("請輸入您要保存的文件名:");
scanf("%s",FileName);
printf("正在將商品信息保存到文件,請稍候……\n");
if((comPtr=fopen(FileName,"w"))==NULL)
printf("沒有該文件\n");
else
for(i=0 ; i<n ; i++)
fprintf(comPtr,"\n%17s%12d%12s%8.1f",com[i].name,com[i].num,com[i].shang,com[i].price);
fclose(comPtr);
}
int DataRead(record *com,int *nptr) /*讀取文件*/
{
int i=0;
char datafile[20];
FILE *comPtr;
*nptr = 0;
printf("請輸入文件名:");
scanf("%s",datafile);
if((comPtr = fopen(datafile,"r")) == NULL) /*打開文件*/
{
printf("沒有該文件,請重新輸入!\n");
return 0;
}
else
{
printf("正在讀取商品單價,請稍候……\n");
while (!feof(comPtr))
{
fscanf(comPtr,"%s%d%s%f",&com[i].name,&com[i].num,&com[i].shang,&com[i].price);
i++;
}
*nptr = i;
printf("\n");
fclose(comPtr);
return 1;
}
}
void DataDisPlay()
{
void OnPrice(record *com,int n ); /*按單價*/
void OnNumber(record *com,int n ); /*按商品號*/
int N;
int i;
record com[300];
char YesNo; /*是否按順序顯示*/
char tp;
if(DataRead(com,&N)==1) /*從文件讀取數據*/
{
printf("序號\t\t商品名\t 商品號\t生產商\t單價\n");
for(i=0;i<N;i++)
printf("%3d%17s%12d%12s%8.1f\n",i+1,com[i].name,com[i].num,com[i].shang,com[i].price);
printf("要按順序顯示嗎?(Y/N)?");
fflush(stdin);
scanf("%c",&YesNo);
if(YesNo=='y'||YesNo=='Y')
{
printf("\t請輸入排序方式:\n");
printf("\t(1.按價格排序從低到高;2.按商品號排序從低到高.)");
fflush(stdin);
scanf("%c",&tp);
if(tp=='1')
OnPrice(com,N);
else if(tp =='2')
OnNumber(com,N);
else
printf("\t輸入了不正確項!\n");
}
}
} /*結束顯示成績*/
void OnPrice(record *com,int n ) /*按單價順序*/
{ int i,j;
record temp;
printf("\t\t按單價排序---\n\n");
printf("商品總數為%d:\n",n);
for(j=0 ; j<n-1 ; j++) /*冒泡排序*/
for(i=0 ; i<n-j-1 ; i++)
if(com[i].price>com[i+1].price)
{
temp=com[i];
com[i]=com[i+1];
com[i+1]=temp;
}
printf("\n\t\t按成績排序的結果如下(按分數從低到高):\n\n");
printf("序號\t\t商品名\t 商品號\t生產商\t單價\n");
for(i=0 ; i<n ; i++)
printf("%3d%17s%12d%12s%8.1f\n",i+1,com[i].name,com[i].num,com[i].shang,
com[i].price);
}
void OnNumber(record *com,int n ) /*按序號順序*/
{
int i,j;
record temp;
printf("\t\t按商品號排序---\n\n");
printf("商品總數為%d:\n",n);
for(j=0 ; j<n-1 ; j++)
for(i=0 ; i<n-j-1 ; i++)
if(com[i].num>com[i+1].num)
{
temp=com[i];
com[i]=com[i+1];
com[i+1]=temp;
}
printf("\n\t按商品號排序的結果如下(按商品號從小到大):\n\n");
printf("序號\t\t商品名\t 商品號\t生產商\t單價\n");
for(i=0 ; i<n ; i++)
printf("%3d%17s%12d%12s%8.1f\n",i+1,com[i].name,com[i].num,com[i].shang,
com[i].price);
}
void DataAdd( ) /*增加*/
{
int i=0,n,m; /*商品名稱*/
char shangming[30];
int haoma; /*生產商*/
char shangjia[10];
float danjia;
char YesOrNo;
record com[SIZE];
printf("\t\t讀取原有數據信息---\n");
if(DataRead(com,&n)==1)
{
printf("\t\t信息讀取完畢!\n\n");
printf("\t\t請輸入要添加的商品總數:");
scanf("%d",&m);
printf("\t\t現在開始錄入這%d個商品信息:\n\n",m);
while(i<m)
{
printf("第%d個商品的商品名:",i+1);
scanf("%s",&shangming);
printf("第%d個商品的商品號:",i+1);
scanf("%d",&haoma);
printf("第%d個商品的生產商:",i+1);
scanf("%s",&shangjia);
printf("第%d個商品的單價:",i+1);
scanf("%f",&danjia);
if(danjia>=0&&danjia<=1000) /*有效的單價才錄入*/
{
strcpy(com[i+n].name,shangming);
com[i+n].num = haoma;
strcpy(com[i+n].shang,shangjia);
com[i+n].price = danjia;
i =i+1;
}
else
printf("輸入的單價是一個無效的值,請重新輸入!\n\n");
}
printf("要保存您剛才錄入的數據嗎(Y/N)?");
fflush(stdin);
scanf("%c",&YesOrNo);
if(YesOrNo=='y'||YesOrNo=='Y')
DataStorage(com,n+m);
else if(YesOrNo=='n'||YesOrNo=='N')
return;
else
printf("輸入了不正確項,返回上一級\n");
return;
}
}
void DataDel( )//刪除
{
void OnNumber(record *com,int n );
record com[SIZE];
int i; /*總記錄數*/
int n; /*要刪除的記錄號*/
int m;
printf("\t\t讀取原有數據信息---\n");
if(DataRead(com,&n)==1)
{
printf("\t\t原始數據如下:\n\n");
OnNumber(com,n );
printf("請輸入你要刪除的記錄的序號");
scanf("%d",&m);
if(m>=1 && m<=n)
{
for(i=m-1;i<n-1;i++)
com [i] = com[i+1];
DataStorage(com,n-1);
}
}
}
void DataStatistic( ) /*統計信息*/
{
int high=0,low=200,ave=0;
int n,i,sum=0;
int g,l;
record com[SIZE];
printf("讀取數據信息---\n");
if(DataRead(com,&n)==1)
{
printf("商品總數為%d\n\n",n);
for(i=0;i<n;i++)
{
if(com[i].price>high)
{
high = com[i].price;
g=i;
}
if(com[i].price<low)
{
low = com[i].price;
l=i;
}
sum += com[i].price;
}
ave=sum/n;
printf("\t\t最高\t最低\t平均\n"); /*計算值*/
printf("商品單價統計:\t%d\t%d\t%d\n\n",high,low,ave);
printf("序號\t\t商品名\t 商品號\t生產商\t單價\n");
for(i=0 ; i<n ; i++)
printf("%3d%17s%12d%12s%8.1f\n",i+1,com[i].name,com[i].num,com[i].shang,
com[i].price);
printf("\t\t 序號\t\t 商品名\t 商品號\t 生產商 單價\n");
printf("單價最高的商品是:%3d%17s%12d%12s%8.1f\n\n",g+1,com[g].name,com[g].num,com[g].shang,com[g].price);
printf("單價最低的商品是:%3d%17s%12d%12s%8.1f\n",l+1,com[l].name,com[l].num,com[l].shang,com[l].price);
} /*結束統計*/
}