学生信息管理系统

学生信息管理系统,要求完成以下基本任务:

1.改写程序为良好程序风格(文档注释,函数注释,语句注释)。

2.将功能补充完全(基于文件处理,完成刷新和保存功能)。

3.将学生信息改为更好的数据组织,而非离散形式(结构体)。

提高要求:可将程序中的不足(如数据验证)等根据自己的能力与理解完成。

程序代码如下:

#include<stdio.h>	/*I/O函数*/
#include<stdlib.h>	/*其它说明*/
#include<string.h>	/*字符串函数*/
#define LEN 15		/* 学号和姓名最大字符数,实际请更改*/
#define N 50		/* 最大学生人数,实际请更改*/
//char* code[N];	/* 学号*/
//char* name[N];	/* 姓名*/
//int age[N];			/* 年龄*/
//char sex[N];		/* 性别*/
//float score[N][3];     /* 3门课程成绩*/
int k=1,n, m;/* n代表当前记录的学生人数*/	 
void seek();         /*查询学生信息函数*/
//void refresh();   /*刷新录入信息函数*/
void readfile();
void modify();      /*修改学生信息*/
void insert();      /*增加学生信息*/
void del();         /*删除信息*/
void display();   /*显示当前信息*/
void save();   /*保存学生信息函数*/
void menu();   /*菜单函数*/

int main()    /*主函数*/
{ 
	while(k)
	{
		menu();
	}
	system("pause");
	return 0;
} 

//定义结构体
struct Student{      
char code[LEN+1]; // 学号
char name[LEN+1]; // 姓名
int age; // 年龄
char sex; // 性别
float score[3];
}stu[N];

void help()   /*系统帮助函数*/
{ 
	printf("\n0.欢迎使用系统帮助!\n");
	printf("\n1.初次进入系统后,请先选择增加学生信息;\n");
	printf("\n2.按照菜单提示键入数字代号;\n");
	printf("\n3.增加学生信息后,切记保存;\n");
	printf("\n4.谢谢您的使用!\n");
	system("pause");
} 

/*void refresh()
{                     //刷新及录入
	int i=0;
	printf("请输入需录入信息的学生的数量:\n");
	scanf("%d",&n);
	do{
		printf("请输入第%d 个学生的学号:\n",i+1);
		scanf("%s",&stu[i].code);
		printf("请输入第%d 个学生的姓名:\n",i+1);
		scanf("%s",&stu[i].name);
		printf("请输入第%d 个学生的年龄:\n",i+1);
		scanf("%d",&stu[i].age);
		printf("请输入第%d 个学生的性别:\n",i+1);
		scanf("%s",&stu[i].sex);
		printf("请输入第%d 个学生的C语言成绩\n",i+1);
		scanf("%d",&stu[i].score[0]);
		printf("请输入第%d 个学生的高等数学成绩:\n",i+1);
		scanf("%d",&stu[i].score[1]);
		printf("请输入第%d 个学生的大学英语成绩:\n",i+1);
		scanf("%d",&stu[i].score[2]);
		i++;
	}while(i<n);
}*/






/*从文件中读人数据,建立信息*/
void readfile(){
	char filename[LEN+1];
	FILE * fp; /*文件指针*/
	int i = 0;
	printf("请输人已存有学生信息的文件名:\n");
		scanf(" %s",filename);
		if ((fp= fopen( filename,"r"))==NULL) /*以只读方式打开指定文件*/
		{
			printf("打开文件%s出错!",filename);
			printf("您需要先选择菜单4增加学生信息.并注意及时保存! \n");
				system(" pause ");
				return;
		}
		while (fscanf(fp,"%s %s %d %c %f %f %f",stu[i].code,stu[i].name,&stu[i].age,&stu[i].sex,
			&stu[i].score[0],&stu[i].score[1],&stu[i].score[2])==7)
/*循环读人学生信息*/
		{
			i++;
		}
		n=i;
		if(0==i)
			printf("文件为空,请选择菜单4增加学生信息,并注意及时保存! \n");
		else
			printf("读人完毕! \n");
		fclose(fp);
		system("pause");
}

void seek() /*查找*/
{
	int i,item,flag;
	char s1[21]; /* 以姓名和学号最长长度+1为准*/
	printf("------------------\n");
	printf("-----1.按学号查询-----\n");
	printf("-----2.按姓名查询-----\n");
	printf("-----3.退出本菜单-----\n");
	printf("------------------\n");
	while(1)
	{
		printf("请选择子菜单编号:");
		scanf("%d",&item);
		flag=0;
		switch(item)
		{
		case 1:
			printf("请输入要查询的学生的学号:\n");
			scanf("%s",s1);
			for(i=0;i<n;i++)
				if(strcmp(stu[i].code,s1)==0)
				{
					flag=1;
					printf("学生学号    学生姓名  年龄   性别  C语言成绩  高等数学  大学英语成绩\n");				
					printf("--------------------------------------------------------------------\n");
					printf("%6s %7s %6d %6c %9.1f %10.1f %10.1f\n",stu[i].code,stu[i].name,
						stu[i].age,stu[i].sex,stu[i].score[0],stu[i].score[1],stu[i].score[2]);
					break;
				}
				if(0==flag)
					printf("该学号不存在!\n"); break;
		case 2:
			printf("请输入要查询的学生的姓名:\n");
			scanf("%s",s1);
			for(i=0;i<n;i++)
				if(strcmp(stu[i].name,s1)==0)
				{
					flag=1;
					printf("学生学号    学生姓名  年龄   性别  C语言成绩  高等数学  大学英语成绩\n");				
					printf("--------------------------------------------------------------------\n");
					printf("%6s %7s %6d %6c %9.1f %10.1f %10.1f\n",stu[i].code,stu[i].name,
						stu[i].age,stu[i].sex,stu[i].score[0],stu[i].score[1],stu[i].score[2]);
				}
					if(0==flag)
						printf("该姓名不存在!\n"); break;
		case 3:return;
		default:printf("请在1-3之间选择\n");
		}
	}
} 


void modify() /*修改信息*/
{
	int i,item,num=-1;
	char sex1,s1[LEN+1],s2[LEN+1]; /* 以姓名和学号最长长度+1为准*/
	float score1;
	printf("请输入要要修改的学生的学号:\n");
	scanf("%s",s1);
	for(i=0;i<n;i++)
		if(strcmp(stu[i].code,s1)==0) /*比较字符串是否相等*/
			num=i;
		if(num!=-1)
		{
			printf("------------------\n");
			printf("1.修改姓名\n");
	    	printf("2.修改年龄\n");
		    printf("3.修改性别\n");
		    printf("4.修改C语言成绩\n");
		    printf("5.修改高等数学成绩\n");
		    printf("6.修改大学英语成绩\n");
		    printf("7.退出本菜单\n");
		    printf("------------------\n");
			while(1)
			{
				printf("请选择子菜单编号:");
				scanf("%d",&item);
				switch(item)
				{
				case 1:
					printf("请输入新的姓名:\n");
				    scanf("%s",s2);
				    strcpy(stu[num].name,s2); break;
				case 2:
				    printf("请输入新的年龄:\n");
				    scanf("%d",&stu[num].age);break;
		    	case 3:
			    	printf("请输入新的性别:\n");
			    	scanf("%c",&sex1);
					stu[num].sex=sex1;break;
		    	case 4:
		    		printf("请输入新的C语言成绩:\n");
		    		scanf("%f",&score1);
					stu[num].score[0]=score1;break;
		     	case 5:
			    	printf("请输入新的高等数学成绩:\n");
			    	scanf("%f",&score1);
					stu[num].score[1]=score1;break;
		    	case 6:
			    	printf("请输入新的大学英语成绩:\n");
			    	scanf("%f",&score1);
					stu[num].score[2]=score1;break;
			    case 7: return;
		    	default:printf("请在1-7之间选择\n");
				}
		}
			printf("修改完毕!显示结果请选择菜单6,并及时保存!\n");
}
		else
		{
			printf("该学号不存在!\n");
			system("pause");
		}
}


void sort()    //按学号排序
{
	int i,j,k,*p,*q,s;
	char temp[LEN+1],ctemp;
	int ftemp;
	for(i=0;i<n-1;i++)  //比较法排序
	{
		for(j=n-1;j>i;j--)
			if(strcmp(stu[j-1].code,stu[j].code)>0)
			{
				strcpy(temp,stu[j-1].code);
				strcpy(stu[j-1].code,stu[j].code);
				strcpy(stu[j].code,temp);
				strcpy(temp,stu[j-1].name);
				strcpy(stu[j-1].name,stu[j].name);
				strcpy(stu[j].name,temp);
				ctemp=stu[j-1].sex;
				stu[j-1].sex=stu[j].sex;
				stu[j].sex=ctemp;
				p=&stu[j-1].age;
				q=&stu[j].age;
				s=*q;
				*q=*p;
				*p=s;
				for(k=0;k<3;k++)
				{
					ftemp=stu[j-1].score[k];
					stu[j-1].score[k]=stu[j].score[k];
					stu[j].score[k]=ftemp;
				}
			}
	}
} 

void insert() /*插入函数*/
{
	int i=n,j,flag;

	printf("请输入待增加的学生数:\n");
	scanf("%d",&m);
	if(m>0)
	{
		do
		{
			flag=1;
			while(flag)
			{
				flag=0;
				printf("请输入第%d位学生的学号:\n",i+1);
				scanf("%s",stu[i].code);
					for(j=0;j<i;j++)
						if(strcmp(stu[i].code,stu[j].code)==0)
						{
							printf("已有该学号,请检查后重新录入!\n");
							flag=1;
							break;
						}
			}
			printf("请输入第%d 个学生的学号:\n",i+1);
		    scanf("%s",&stu[i].code);
	    	printf("请输入第%d 个学生的姓名:\n",i+1);
	     	scanf("%s",&stu[i].name);
	    	printf("请输入第%d 个学生的年龄:\n",i+1);
	    	scanf("%d",&stu[i].age);
	    	printf("请输入第%d 个学生的性别:\n",i+1);
    		scanf(" %c",&stu[i].sex);
    		printf("请输入第%d 个学生的C语言成绩\n",i+1);
    		scanf("%f",&stu[i].score[0]);
     		printf("请输入第%d 个学生的高等数学成绩:\n",i+1);
	    	scanf("%f",&stu[i].score[1]);
	    	printf("请输入第%d 个学生的大学英语成绩:\n",i+1);
	    	scanf("%f",&stu[i].score[2]);
			if(0==flag)
			{
				i++;
			}
		}while(i<n+m);
	}
	n+=m;
	printf("信息增加完毕!\n\n");
	sort();
	system("pause");
} 

void del()   /*删除函数*/
{
	int i,j,flag=0;
	char s1[LEN+1];
	printf("请输入要删除学生的学号:\n");
	scanf("%s",s1);
	for(i=0;i<n;i++)
		if(strcmp(stu[i].code,s1)==0)
		{
			flag=1;   //查找成功
			for(j=i;j<n-1;j++)
				stu[j]=stu[j+1];
			/*	strcpy(stu[j].code,stu[j+1].code);
			strcpy(stu[j].name,stu[j+1].name);
			stu[j].age=stu[j+1].age;
			strcpy(stu[j].sex,stu[j+1].sex);
			stu[j].score[0]=stu[j+1].score[0];
			stu[j].score[1]=stu[j+1].score[1];
			stu[j].score[2]=stu[j+1].score[2];*/
		}
		if(flag==0)   //查找失败
			printf("该学号不存在!\n");
		if(flag==1)
		{
			printf("删除成功,显示结果请选择菜单\n");
			n--;
		}
		system("pause");
} 


void display()   /*显示信息函数*/
{
	int i;
	printf("共有%d位学生的信息:\n",n);
	if(0!=n)
	{
		printf("学生学号  学生姓名 年龄  性别  C语言成绩  高等数学  大学英语成绩\n");				
		printf("--------------------------------------------------------------------\n");
		for(i=0;i<n;i++)
		{ 
			printf("%7s %7s %6d %6c %9.1f %10.1f %10.1f\n",stu[i].code,stu[i].name,stu[i].age,
				stu[i].sex,stu[i].score[0],stu[i].score[1],stu[i].score[2]);
		}
	}
	system("pause");
} 

void save()    //保存当前学生信息函数
{
	FILE *fp;
	int i;      //定义一个指向文件型数据的指针变量
	char filename[LEN+1];
	printf("请输入文件名:\n");
	scanf("%s",filename);
	fp=fopen(filename,"w");
	for(i=0;i<n;i++)
	{
		fprintf(fp,"%s%s%d%c%.1f%.1f%.1f\n",stu[i].code,stu[i].name,stu[i].age,
				stu[i].sex,stu[i].score[0],stu[i].score[1],stu[i].score[2]);
	}
	printf("保存成功!\n");
	fclose(fp);      //关闭文件
	system("pause");
}


    /*char * h[7]={"学号","姓名","年龄","性别","C语言","高数","大英"}; //文件中的标题栏
	if((fp=fopen("C:\\Users\\HDD\\Desktop\\save.txt","w"))==NULL)
	{
		printf("该文件为空!");
		exit(0);
	}
	for(j;j<7;j++)    //在文件中显示标题栏
	{   
		fputs(h[j],fp);fputs("  ",fp);
	}
	fputs("\n",fp);
	for(i;i<n;i++){     //在文件中显示学生的信息
		fputs(stu[i].code,fp);fputs("     ",fp);
		fputs(stu[i].name,fp);fputs("     ",fp);
		fprintf(fp,"%2d",stu[i].age);fputs("    ",fp);
		fputs(stu[i].sex,fp);fputs("     ",fp);
		fprintf(fp,"%2d",stu[i].score[0]);fputs("     ",fp);
		fprintf(fp,"%2d",stu[i].score[1]);fputs("     ",fp);
		fprintf(fp,"%2d",stu[i].score[2]);fputs("\n",fp);
	}
	printf("保存成功!\n");
	fclose(fp);      //关闭文件
}*/



void menu()/* 开始界面*/
{
	int num;
	printf(" \n\n                    \n\n");
	printf("  ******************************************************\n\n");
	printf("  *                学生信息管理系统                    *\n \n");
	printf("  ******************************************************\n\n"); 
	printf("*********************系统功能菜单*************************       \n");
	printf("     ----------------------   ----------------------   \n");
	printf("     *********************************************     \n");
	printf("     * 0.系统帮助及说明  * *  1.刷新学生信息   *     \n");
	printf("     *********************************************     \n"); 
	printf("     * 2.查询学生信息    * *  3.修改学生信息   *     \n");
	printf("     *********************************************     \n");
	printf("     * 4.增加学生信息    * *  5.按学号删除信息 *     \n");
	printf("     *********************************************     \n");
	printf("     * 6.显示当前信息    * *  7.保存当前学生信息*     \n");
	printf("     ********************** **********************     \n");
	printf("     * 8.退出系统        *                            \n");
	printf("     **********************                            \n");
	printf("     ----------------------   ----------------------                           \n");
	printf("请选择菜单编号:");
	scanf("%d",&num);
	switch(num)
	{ 
	case 0:help();break;
	case 1:readfile();break;
	case 2:seek();break;
	case 3:modify();break;
	case 4:insert();break;
 	case 5:del();break;
 	case 6:display();break;
	case 7:save();break;
	case 8:k=0;printf("即将退出程序!\n");break;
	default:printf("请在0-8之间选择\n");
	}
}

该代码还存在一些问题,增加学生信息后,会陷入循环

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
public void freshTable(String sql){ myConnection conn=new myConnection(); ResultSet rs; rs=conn.getResult(sql); if (rs!=null){ try{ mm.setRowCount(0); table.setModel(mm); while(rs.next()){ String 学号 = rs.getString("学号"); String 姓名 = rs.getString("姓名"); String 性别 = rs.getString("性别"); String 民族 = rs.getString("民族"); String 年龄 = rs.getString("年龄"); String 年级 = rs.getString("年级"); String 班级 = rs.getString("班级"); String 专业 = rs.getString("专业"); String[] cloumns ={学号,姓名,性别,民族,年龄,年级,班级,专业}; mm.addRow(cloumns); } //table.clearSelection(); table.setModel(mm); }catch(Exception e){ System.out.println(e.toString()); } } } public void actionPerformed(ActionEvent e){ //退出 if (e.getSource()==miExit){ System.exit(0); //查找 }else if(e.getSource()==miFind){ findFrame ff=new findFrame(this); ff.setVisible(true); //添加 }else if(e.getSource()==miAdd){ addFrame af=new addFrame(this); af.setVisible(true); //修改 }else if(e.getSource()==miEdit){ if (table.getSelectedRow()==-1){ JOptionPane.showMessageDialog(null, "请选择你要修改的内容", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else{ editFrame ef=new editFrame(this); ef.学号.setText((String)table.getValueAt(table.getSelectedRow(),0)); ef.姓名.setText((String)table.getValueAt(table.getSelectedRow(),1)); ef.性别.setText((String)table.getValueAt(table.getSelectedRow(),2)); ef.民族.setText((String)table.getValueAt(table.getSelectedRow(),3)); ef.年龄.setText((String)table.getValueAt(table.getSelectedRow(),4)); ef.年级.setText((String)table.getValueAt(table.getSelectedRow(),5)); ef.班级.setText((String)table.getValueAt(table.getSelectedRow(),6)); ef.专业.setText((String)table.getValueAt(table.getSelectedRow(),7)); ef.setVisible(true); this.freshTable("select * from 学生信息表"); } //删除 }else if(e.getSource()==miDel){ if (table.getSelectedRow()==-1){ JOptionPane.showMessageDialog(null, "请选择你要删除的行", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else { String sql="delete from 学生信息表 where 学号 = '"+table.getValueAt(table.getSelectedRow(),0)+"'"; //JOptionPane.showMessageDialog(null, sql, "温馨提示", JOptionPane.INFORMATION_MESSAGE); myConnection conn=new myConnection(); if (conn.executeSql(sql)){ JOptionPane.showMessageDialog(null, "成功删除", "温馨提示", JOptionPane.INFORMATION_MESSAGE); this.freshTable("select * from 学生信息表"); }else { JOptionPane.showMessageDialog(null, "未知错误", "删除失败", JOptionPane.INFORMATION_MESSAGE); } } //显示 }else if(e.getSource()==miShow){ //JOptionPane.showMessageDialog(null, "未知错误", "删除失败", JOptionPane.INFORMATION_MESSAGE); this.freshTable("select * from 学生信息表"); //用户管理 }else if(e.getSource()==miUser){ userFrame uf=new userFrame(); uf.setVisible(true); //关于 }else if(e.getSource()==miAbout){ aboutFrame af=new aboutFrame(); af.setVisible(true); } } } class myConnection{ ResultSet re; String strurl = "jdbc:odbc:driver={Microsoft Access Driver (*.mdb)};DBQ=学生管理数据库.mdb"; public myConnection(){} public ResultSet getResult(String sql){ try{ Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); Connection conn=DriverManager.getConnection(strurl); Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE); ResultSet re=stmt.executeQuery(sql); return re; } catch(Exception e){ System.out.println("getResult------"+e.toString()); return null; } } public boolean executeSql(String sql){ try{ Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); Connection conn=DriverManager.getConnection(strurl); Statement stmt=conn.createStatement(); stmt.executeUpdate(sql); conn.commit(); return true; } catch(Exception e){ System.out.println("executeSql----"+e.toString()); return false; } } } class addFrame extends JDialog implements ActionListener{ public static final int WIDTH = 400; public static final int HEIGHT = 400; JLabel 学号1,姓名1,性别1,民族1,年龄1,年级1,班级1,专业1; JTextField 学号,姓名,性别,民族,年龄,年级,班级,专业; JButton b; JPanel p; mainFrame mf; public addFrame(mainFrame mmf){ setTitle("修改学生信息"); setSize(WIDTH,HEIGHT); setLocation(120,180); Container contentPane = getContentPane(); contentPane.setLayout(new FlowLayout()); 学号1=new JLabel("学号"); 姓名1=new JLabel("姓名"); 性别1=new JLabel("性别"); 民族1=new JLabel("民族"); 年龄1=new JLabel("年龄"); 年级1=new JLabel("年级"); 班级1=new JLabel("班级"); 专业1=new JLabel("专业"); 学号=new JTextField(5); 姓名=new JTextField(5); 性别=new JTextField(5); 民族=new JTextField(5); 年龄=new JTextField(5); 年级=new JTextField(5); 班级=new JTextField(10); 专业=new JTextField(10); b=new JButton("确定"); p=new JPanel(); p.setLayout(new GridLayout(10,2,5,5)); p.add(学号1); p.add(学号); p.add(姓名1); p.add(姓名); p.add(性别1); p.add(性别); p.add(民族1); p.add(民族); p.add(年龄1); p.add(年龄); p.add(年级1); p.add(年级); p.add(班级1); p.add(班级); p.add(专业1); p.add(专业); p.add(new Label("")); p.add(new Label("")); p.add(b); contentPane.add(p); //添加按钮监听器 b.addActionListener(this); mf=mmf; } public void actionPerformed(ActionEvent e){ if (学号.getText().toString().equals("")){ JOptionPane.showMessageDialog(null, "请输入学号", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else if (姓名.getText().toString().equals("")){ JOptionPane.showMessageDialog(null, "请输入姓名", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else if (年龄.getText().toString().equals("")){ JOptionPane.showMessageDialog(null, "请输入年龄", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else{ String sql="select * from 学生信息表 where 学号='" + 学号.getText() + "'"; myConnection conn=new myConnection(); ResultSet rs; rs=conn.getResult(sql); try{ //System.out.println(rs.getRow()); if (rs.next()){ JOptionPane.showMessageDialog(null, "此学号已经存在", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else{ sql="insert into 学生信息表 values('" +学号.getText()+"','"+ 姓名.getText() +"','"+ 性别.getText() +"','"+ 民族.getText() +"',"+ 年龄.getText() +",'"+ 年级.getText() +"','"+ 班级.getText() +"','"+ 专业.getText() +"')"; if (conn.executeSql(sql)){ JOptionPane.showMessageDialog(null, "添加成功", "温馨提示", JOptionPane.INFORMATION_MESSAGE); mf.freshTable("select * from 学生信息表"); 学号.setText(""); 姓名.setText(""); 性别.setText(""); 民族.setText(""); 年龄.setText(""); 年级.setText(""); 班级.setText(""); 专业.setText(""); }else{ JOptionPane.showMessageDialog(null, "添加失败", "温馨提示", JOptionPane.INFORMATION_MESSAGE); } } }catch(Exception er){ System.out.println(er.toString()); } } } } class editFrame extends JDialog implements ActionListener{ public static final int WIDTH = 400; public static final int HEIGHT = 400; JLabel 学号1,姓名1,性别1,民族1,年龄1,年级1,班级1,专业1; JTextField 学号,姓名,性别,民族,年龄,年级,班级,专业; JButton b; JPanel p; mainFrame mf; public editFrame(mainFrame mmf){ setTitle("修改学生信息"); setSize(WIDTH,HEIGHT); setLocation(120,180); Container contentPane = getContentPane(); contentPane.setLayout(new FlowLayout()); 学号1=new JLabel("学号"); 姓名1=new JLabel("姓名"); 性别1=new JLabel("性别"); 民族1=new JLabel("民族"); 年龄1=new JLabel("年龄"); 年级1=new JLabel("年级"); 班级1=new JLabel("班级"); 专业1=new JLabel("专业"); 学号=new JTextField(5); 姓名=new JTextField(5); 性别=new JTextField(5); 民族=new JTextField(5); 年龄=new JTextField(5); 年级=new JTextField(5); 班级=new JTextField(10); 专业=new JTextField(10); 学号.setEnabled(false); b=new JButton("确定"); p=new JPanel(); p.setLayout(new GridLayout(10,2,5,5)); p.add(学号1); p.add(学号); p.add(姓名1); p.add(姓名); p.add(性别1); p.add(性别); p.add(民族1); p.add(民族); p.add(年龄1); p.add(年龄); p.add(年级1); p.add(年级); p.add(班级1); p.add(班级); p.add(专业1); p.add(专业); p.add(new Label("")); p.add(new Label("")); p.add(b); contentPane.add(p); //添加按钮监听器 b.addActionListener(this); mf=mmf; } public void actionPerformed(ActionEvent e){ if (学号.getText().toString().equals("")){ JOptionPane.showMessageDialog(null, "请输入学号", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else if (姓名.getText().toString().equals("")){ JOptionPane.showMessageDialog(null, "请输入姓名", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else if (年龄.getText().toString().equals("")){ JOptionPane.showMessageDialog(null, "请输入年龄", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else{ String sql="update 学生信息表 set 姓名='"+姓名.getText()+"',性别='"+性别.getText()+"',年龄="+年龄.getText()+",年级='"+年级.getText()+"',班级='"+班级.getText()+"',专业='"+专业.getText()+"',民族='"+民族.getText()+"' where 学号='" + 学号.getText() + "'"; myConnection conn=new myConnection(); try{ //JOptionPane.showMessageDialog(null, sql, "温馨提示", JOptionPane.INFORMATION_MESSAGE); if (conn.executeSql(sql)){ JOptionPane.showMessageDialog(null, "修改成功", "温馨提示", JOptionPane.INFORMATION_MESSAGE); mf.freshTable("select * from 学生信息表"); this.dispose(); }else{ JOptionPane.showMessageDialog(null, "修改失败", "温馨提示", JOptionPane.INFORMATION_MESSAGE); } }catch(Exception er){ System.out.println(er.toString()); } } } } class findFrame extends JDialog implements ActionListener{ mainFrame mf; JPanel p; JComboBox c; JTextField t; JButton b; JButton fAll; String sql="select * from student"; String[] colStr={"学号","姓名","性别","民族","年龄","年级","班级","专业"}; public findFrame(mainFrame mmf){ mf=mmf; p=new JPanel(); c=new JComboBox(colStr); t=new JTextField(10); b=new JButton("查找"); fAll=new JButton("全部显示"); b.addActionListener(this); fAll.addActionListener(this); p.add(new JLabel("选择")); p.add(c); p.add(new JLabel("查找内容")); p.add(t); p.add(b); p.add(fAll); this.add(p); this.setTitle("查找"); this.setSize(450,80); } public void actionPerformed(ActionEvent e){ //查找 if (e.getSource()==b){ String selectStr=c.getSelectedItem().toString(); if (selectStr=="年龄"){ sql="select * from 学生信息表 where "+selectStr+" = "+t.getText().toString(); } else { sql="select * from 学生信息表 where "+selectStr+" = '"+t.getText().toString()+"'"; } mf.freshTable(sql); //全部显示 }if (e.getSource()==fAll){ sql="select * from 学生信息表"; mf.freshTable(sql); } } } class aboutFrame extends JDialog{ aboutFrame(){ JPanel p1=new JPanel(); p1.add(new JLabel("学生信息管理系统")); p1.add(new JLabel("版权所有:农福刚")); p1.add(new JLabel("农福刚有限责任公司出口")); p1.add(new JLabel("QQ:14159391")); p1.setLayout(new GridLayout(4,1,5,5)); this.add(p1); this.setTitle("关于我"); this.setSize(300,200); } } class userFrame extends JFrame implements ActionListener{ JTextField user,pass; JButton add,del; JTable t; JPanel p1,p2,p3,p4,p5; DefaultTableModel m; public userFrame(){ p1=new JPanel(); p2=new JPanel(); p3=new JPanel(); p4=new JPanel(); p5=new JPanel(); user=new JTextField(8); pass=new JTextField(8); add=new JButton("添加"); del=new JButton("删除"); String[] col = {"用户名","密码"}; m= new DefaultTableModel(col,0); t=new JTable(); t.setModel(m); JScrollPane sp = new JScrollPane(t); p1.add(new JLabel("用户名")); p1.add(user); p1.add(new JLabel("密码")); p1.add(pass); p1.add(add); p2.add(sp); p3.add(del); add.addActionListener(this); del.addActionListener(this); myConnection conn=new myConnection(); ResultSet rs; rs=conn.getResult("select * from 管理员"); if (rs!=null){ try{ //m.setRowCount(0); //table.setModel(mm); while(rs.next()){ String 用户名 = rs.getString("用户名"); String 密码 = rs.getString("密码"); String[] cloumns ={用户名,密码}; m.addRow(cloumns); } t.setModel(m); }catch(Exception e){ System.out.println(e.toString()); } } this.add(p1,BorderLayout.NORTH); this.add(p2,BorderLayout.CENTER); this.add(p3,BorderLayout.SOUTH); this.add(p4,BorderLayout.WEST); this.add(p5,BorderLayout.EAST); this.setTitle("用户管理"); this.setSize(600,400); } public void actionPerformed(ActionEvent e){ //添加 if (e.getSource()==add){ if (user.getText().toString().equals("")){ JOptionPane.showMessageDialog(null, "请输入用户名", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else if (pass.getText().toString().equals("")){ JOptionPane.showMessageDialog(null, "请输入密码", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else{ myConnection conn=new myConnection(); ResultSet rs; try{ rs=conn.getResult("select * from 管理员 where 用户名='"+user.getText().toString()+"'"); if (rs.next()){ JOptionPane.showMessageDialog(null, "此用户已经存在", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else{ if (conn.executeSql("insert into 管理员 values('"+user.getText().toString()+"','"+pass.getText().toString()+"')")){ String[] newUser={user.getText(),pass.getText()}; m.addRow(newUser); t.setModel(m); JOptionPane.showMessageDialog(null, "添加成功", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else{ JOptionPane.showMessageDialog(null, "添加失败", "温馨提示", JOptionPane.INFORMATION_MESSAGE); } } }catch(Exception er){ System.out.println(er.toString()); } } //删除 }else if (e.getSource()==del){ if (t.getSelectedRow()==-1){ JOptionPane.showMessageDialog(null, "请选择你要删除的行", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else { String sql="delete from 管理员 where 用户名 = '"+t.getValueAt(t.getSelectedRow(),0)+"'"; //JOptionPane.showMessageDialog(null, sql, "温馨提示", JOptionPane.INFORMATION_MESSAGE); myConnection conn=new myConnection(); if (conn.executeSql(sql)){ m.removeRow(t.getSelectedRow()); t.setModel(m); //t.removeRowSelectionInterval(); JOptionPane.showMessageDialog(null, "成功删除", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else { JOptionPane.showMessageDialog(null, "未知错误", "删除失败", JOptionPane.INFORMATION_MESSAGE); } } } } } class loginFrame extends JDialog implements ActionListener{ JPanel p; JTextField user,pass; JButton login,cancel; public loginFrame(){ p=new JPanel(); user=new JTextField(10); pass=new JTextField(10); login=new JButton("登录"); cancel=new JButton("退出"); user.setText("admin"); pass.setText("admin"); login.addActionListener(this); cancel.addActionListener(this); p.add(new JLabel("账号")); p.add(user); p.add(new JLabel("密码")); p.add(pass); p.add(login); p.add(cancel); this.add(p); this.setTitle("系统登录"); this.setSize(180,130); } public void actionPerformed(ActionEvent e){ //查找 if (e.getSource()==login){ if (user.getText().toString().equals("")){ JOptionPane.showMessageDialog(null, "请输入用户名", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else if (pass.getText().toString().equals("")){ JOptionPane.showMessageDialog(null, "请输入密码", "温馨提示", JOptionPane.INFORMATION_MESSAGE); }else{ myConnection conn=new myConnection(); ResultSet rs; String sql="select * from 管理员 where 用户名 = '"+user.getText().toString()+"' and 密码 = '"+pass.getText().toString()+"'"; try{ rs=conn.getResult(sql); if (rs.next()){ this.dispose(); //JOptionPane.showMessageDialog(null, "此用户已经存在", "温馨提示", JOptionPane.INFORMATION_MESSAGE); sql="select * from 学生信息表"; mainFrame mf=new mainFrame(); mf.setTitle("农福刚学生信息管理系统"); mf.setSize(600,486); mf.freshTable(sql); mf.setVisible(true); mf.addWindowListener(new WindowAdapter(){ public void windowClosing(WindowEvent e){ System.exit(0); } }); }else{ JOptionPane.showMessageDialog(null, "用户名或密码错误", "登录失败", JOptionPane.INFORMATION_MESSAGE); } }catch(Exception er){ System.out.println(er.toString()); } } //全部显示 }if (e.getSource()==cancel){ System.exit(0); } } }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值