简易学生信息系统(2.0)

实验3 类和对象

实验内容
1、完成一个简易学生信息系统,至少需要实现以下功能:增加、删除学生信息,浏览学生信息,可以根据姓名或者学号查询学生信息,可以统计学生人数。每位学生信息包含姓名、学号、年龄、班级等基本信息。
其他要求如下:
(1)要求应用面向对象程序设计的思想,根据给定的需求进行分析,设计、实现合理的类。
(2)源代码为多文件工程项目,头文件中进行类的声明,在源文件中实现类定义。
(3)统计学生人数的变量不能是全局变量。
(4)将某些不改变数据成员值的成员函数设计为常成员函数,还有一些函数内部的形参,必要时加const以保护对应实参值不被改变。
(5)增加和删除学生要分别考虑是否满和是否为空的边界条件。
(6)代码总行数不能超过300行。
Problem
在实验中遇到了一个印象深刻的问题。我采用数组的方式来存储多个学生对象,在删除时我是通过找到学生坐标,然后将后面元素向前移动,最终反映学生数量的变量-1. 在写程序的过程中我将学生坐标设为num,然后采用循环执行 student[num++]=student[num]; 结果运行时出错了,我又改为 student[num]=student[++num]; 还是不可以。当把自增移到外面时才可以:student[num]=student[num+1];num++;
最后找到了原因.赋值顺序是自右向左的,所以先执行右边的部分,而我在设计时潜意识以为是自左向右所以两次修改都错了,所以上边修改的和刚开始错的都没有进行数据的交换,只是执行了自己给自己赋值的操作。因此应该把程序改为:student[num++]=student[num+1]; 或 student[num-1]=student[++num];
实验步骤
1.建立一个工程——实验3.
2.在工程下创建两个源文件:main.cpp和class.cpp,分别用来写主函数和类的实现;及一个头文件:header.h,用来定义类。
3.在各个文件中输入代码

//header.h文件
//对类进行定义
//
#ifndef HEADER_H
#define HEADER_H
#include <string>
#include <iostream>
using namespace std;
//定义Student类
class Student
{
public:
	Student(string name_ = "0", string id_="0", int age_ = 0, string grade_="0"):name(name_),id(id_),age(age_),grade(grade_){}
	Student(const Student &sthdent);
	~Student() {}
	string ShowName()const;
	string ShowId()const;
	int ShowAge()const;
	string ShowGrade()const;
	string GetName()const;
	string GetId()const;
	int GetAge()const;
	string GetGrade()const;
	string SetName(string name_);
	string SetId(string id_);
	int SetAge(int age_);
	string SetGrade(string grade_);
	void ShowInformation()const;
private:
	string name; string id; int age; string grade;
};
//定义学生管理类
class Manage
{
public:
	Manage(){size=0;}
	Manage(Manage &student_manage){}
	~Manage(){}
	void AddStudent();
	void SeekByName()const;
	int SeekById()const;
	void ReadAll()const;
	int StudentNumber()const;
	void DeleteStudent();
	void Menu()const;
	void Connection();
private:
	Student student[101];//学生从a[1]->a[100]存储
	int size;
};
#endif

//class.cpp
//类的实现
//
//#include "header.h"
//Student类 
inline Student::Student(const Student &student){
	name = student.name;
	id = student.id;
	age = student.age;
	grade = student.grade;
}
inline string Student::ShowName()const {
	cout << name;
	return name;
}
inline string Student::ShowId()const {
	cout << id;
	return id;
}
inline int Student::ShowAge()const {
	cout << age;
	return age;
}
inline string Student::ShowGrade()const {
	cout << grade;
	return grade;
}
inline string Student::GetName()const {
	return name;
}
inline string Student::GetId()const {
	return id;
}
inline int Student::GetAge()const {
	return age;
}
inline string Student::GetGrade()const {
	return grade;
}
inline string Student::SetName(string name_) {
	name = name_;
	return name;
}
inline string Student::SetId(string id_) {
	id = id_;
	return id;
}
inline int Student::SetAge(int age_) {
	age = age_;
	return age;
}
inline string Student::SetGrade(string grade_) {
	grade = grade_;
	return grade;
}
inline void Student::ShowInformation()const{
	cout<<"姓名:\t"<<name<<"\t学号:\t"<<id<<"\t年龄:\t" <<age<<"\t班级:\t" <<grade<<endl;
}
//Manage类
inline int Manage::StudentNumber()const{
	cout<<"学生的数目为:"<<size<<endl;
	return size;
}
void Manage::AddStudent(){
	if(size==100){
		cout<<"人数已满,无法添加!"<<endl;//判断人是否已满 
		return; 
	}
	string name_;
	cout<<"请输入学生的姓名:";
	cin>>name_;
	student[++size].SetName(name_);
	string id_;
	cout<<"请输入学生的学号:";
	cin>>id_;
	student[size].SetId(id_);
	int age_;
	cout<<"请输入学生的年龄:";
	cin>>age_;
	student[size].SetAge(age_);
	string grade_;
	cout<<"请输入学生的班级:";
	cin>>grade_;
	student[size].SetGrade(grade_);
	return; 
}
void Manage::SeekByName()const{
	if(size<1){
		cout<<"没有学生信息!"<<endl;//判断是否为空
		return;
	}
	string name_;
	cout<<"请输入要查找的学生的姓名:";
	cin>>name_;
	bool flag=true;
	for(int i=1;i<=size;i++){
		if(student[i].GetName()==name_){
			student[i].ShowInformation();
			flag=false;
		}
	}
	if(flag){
		cout<<"没有找到该学生信息"; 
	}
	return;
}
int Manage::SeekById()const{
	if(size<1){
		cout<<"没有学生信息!"<<endl;//判断是否为空
		return 0;
	}
	string id_;
	cout<<"请输入学生的学号:";
	cin>>id_;
	for(int i=1;i<=size;i++){
		if(student[i].GetId()==id_){
			student[i].ShowInformation();
			return i;
		}
	}
	cout<<"没有找到该学生信息"; 
	return 0;
}
void Manage::ReadAll()const{
	if(size==0){
		cout<<"没有学生信息!"<<endl;
		return; 
	}
	cout<<"所有学生的信息:"<<endl;
	for(int i=1;i<=size;i++){
		student[i].ShowInformation();
	}
	return;
}
void Manage::DeleteStudent(){
	int num=SeekById();
	if(num){//判断是否为空
		cout<<"正在删除..."<<endl;
		while(num<size){
			student[num++]=student[num+1];//赋值顺序为自右向左!!! 
		}
		size--;
		cout<<"已删除!"<<endl;
	}
	return;
}
void Manage::Menu()const{
	cout<<"\t*********************************"<<endl;
	cout<<"\t**     学生信息管理系统        **"<<endl;
	cout<<"\t**                             **"<<endl;
	cout<<"\t**     1.添加学生信息          **"<<endl;
	cout<<"\t**     2.根据姓名查找          **"<<endl;
	cout<<"\t**     3.根据学号查找          **"<<endl;
	cout<<"\t**     4.查看所有学生信息      **"<<endl;
	cout<<"\t**     5.统计学生数量          **"<<endl;
	cout<<"\t**     6.删除学生              **"<<endl;
	cout<<"\t**     0.退出                  **"<<endl;
	cout<<"\t**                             **"<<endl;
	cout<<"\t*********************************"<<endl;
	cout<<endl<<"请输入您要进行的操作:";
	return; 
}
void Manage::Connection(){
	int menu=-1;
	while(menu){
		system("cls");
		Menu();
		cin>>menu;
		switch(menu)
		{
			case 0:break;
			case 1:{
				system("cls");
				AddStudent();
				break;
			}
			case 2:{
				system("cls");
				SeekByName();
				system("pause");
				break;
			}
			case 3:{
				system("cls");
				SeekById();
				system("pause");
				break;
			}
			case 4:{
				system("cls");
				ReadAll();
				system("pause");
				break;
			}
			case 5:{
				system("cls");
				StudentNumber();
				system("pause");
				break;
			}
			case 6:{
				system("cls");
				DeleteStudent();
				system("pause");
				break;
			}
			default:{
				cout<<"输入有误,请重新输入!"<<endl;
				menu=-1;
				system("pause");
				break;
			}	
		}
	}
	return;
}

//main.cpp
//主函数
//
//#include "header.h"
int main()
{
	Manage student_manage1;
	student_manage1.Connection();
	return 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、付费专栏及课程。

余额充值