学生信息管理系统

.题目分析

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

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

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

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

提高要求:

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

.关键算法构造

  绘制出关键算法的流程图以及N-S盒图。

读入学生信息                                           

保存当前学生信息

三.代码实现

 

#include<stdio.h>	/*I/O函数*/
#include<stdlib.h>	/*其它说明*/
#include<string.h>	/*字符串函数*/
#define LEN 15		/* 学号和姓名最大字符数,实际请更改*/
#define N 50		/* 最大学生人数,实际请更改*/
struct record//学生信息结构体
{
char code[LEN+1];	/* 学号*/
char name[LEN+1];	/* 姓名*/
int age;			/* 年龄*/
char sex;		/* 性别*/
int score[3];     /* 3门课程成绩*/    
}stu[N];//定义结构体数组
int k=1,n,m;/* n代表当前记录的学生人数*/
//函数声明	 
void readfile();//读入数据
void seek();//查找
void modify();//修改数据
void insert();//插入数据
void del();//删除数据
void display();//显示信息
void save();//保存信息
void menu(); //用户界面
void help();//帮助
int main()
{ 
	while(k)
	{
		menu();
	}
	return 0;
} 
//帮助
void help()
{ 
	printf("\n0.欢迎使用系统帮助!\n");
	printf("\n1.进入系统后,先文件中读入学生信息,再使用其他功能;\n 如果文件不存在或文件中无内容,请选择增加学生信息;\n");
	printf("\n2.按照菜单提示键入数字代号;\n");
	printf("\n3.增加学生信息后,切记保存;\n");
	printf("\n4.谢谢您的使用!\n");//发出一个DOS命令,屏幕上输出"请按任意键继续..."
	system("pause");//
}
// 从文件中读入数据,建立信息
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 %6d %6d %6d",stu[i].code,stu[i].name,&stu[i].age,&stu[i].sex,&stu[i].score[0],&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 %8s %7d %4c %6d %6d %6d\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 %6d %6d %6d\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;//item代表选择修改的子菜单编号,num保存要修改信息的学生的序号
	char sex1,s1[LEN+1],s2[LEN+1]; /* 以姓名和学号最长长度+1为准*/
	int 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("%6d",&score1);
				stu[num].score[0]=score1; break;
			case 5:
				printf("请输入新的高等数学成绩:\n");
				scanf("%6d",&score1);
				stu[num].score[1]=score1; break;
			case 6:
				printf("请输入新的大学英语成绩:\n");
				scanf("%6d",&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;//n为现有学生人数
	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++)//与之前已有学号比较,如果重复,则置flag为1,重新进入循环体内输入
				if(strcmp(stu[i].code,stu[j].code)==0)
				{
				  printf("已有该学号,请检查后重新录入!\n");
				  flag=1;
				  break;//如有重复立即退出该层循环,提高判断速度
				}
		}
		printf("请输入第%d 个学生的姓名:\n",i+1);
		scanf("%s",stu[i].name);
		printf("请输入第%d 个学生的年龄:\n",i+1);
		scanf("%d",&stu[i].age);
		printf("请输入第%d 个学生的性别(“F”or“M”):\n",i+1);
		scanf(" %c",&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]);
		if(0==flag)//与之前已有学生学号无重复,学生人数加1
		{
		  i++;
		}
	}while(i<n+m);
	}
	n+=m;
	printf("信息增加完毕!显示结果请选择菜单6,并请及时保存\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];
		}
		
		if(0==flag)//查找失败
			printf("该学号不存在!\n");
		if(1==flag)
		{
			printf("删除成功,显示结果请选择菜单6,并请及时保存\n");
			n--;//删除成功后,学生人数减1
		}
		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 %6d %6d %6d\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()
{
   int i;
   FILE *fp;//文件指针
   char filename[LEN+1];//文件名
   printf("请输入欲将学生信息写入的文件名:\n");
   scanf("%s",filename);
   fp=fopen(filename,"w");//以写入方式打开文件
   for(i=0;i<n;i++)
   {
     fprintf(fp,"%7s %7s %6d %6c %6d %6d %6d\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");
}
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");
	}
}

  

.调试、测试及运行结果

1.调试

2.测试及运行结果

测试过程中保存学生信息功能有误,然后发现未调用函数save()

帮助功能:

读入信息功能

修改学生信息功能

增加学生信息功能

删除学生信息功能

显示当前信息功能

保存当前学生信息功能

退出系统功能

.经验归纳

  此次上机作业是完善学生信息管理系统,在完善功能时,遇到了很多错误。

①过此次的上机学会了如何使用文件,以前的基础不好,加上实践性不强,导致对文件的使用一窍不通;

②现将数据定义在结构体中,对于结构体里数据的调用必须全改成“结构体名.数据”;

③在增添代码时,在do…while语句的使用时忘记了最后一个花括号,导致出现了好几个错误,对于do…while语句的使用不够熟练;

最后发现贵在实践,通过实践许多问题都能暴露出来,从而获得很大进步。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值