java学生学籍管理系统培训资料

合集下载

Java课程设计——学生学籍管理系统

Java课程设计——学生学籍管理系统

┊┊┊┊┊┊┊┊┊┊┊┊┊装┊┊┊┊┊订┊┊┊┊┊线┊┊┊┊┊┊┊┊┊┊┊┊┊目录一、设计目的 (2)二、功能介绍 (2)三、程序流程 (3)四、设计步骤 (4)五、设计总结 (11)六、程序清单 (11)七、参考文献 (17)┊┊┊┊┊┊┊┊┊┊┊┊┊装┊┊┊┊┊订┊┊┊┊┊线┊┊┊┊┊┊┊┊┊┊┊┊┊一、设计目的《java课程设计》是计算机相关专业的必修专业基础课程,其实践性,应用性很强。

实践教学环节是必不可少的一个重要环节。

本课程的程序设计专题实际是计算机相关专业学生学习《java程序设计》课程后,进行的一次全面的综合训练,java程序设计的目的是加深对理论教学内容的理解和掌握,是学生较系统的掌握程序设计及其在网络开发中的广泛应用,基本方法及技巧,为学生综合运用所学知识,利用软件工程为基础进行软件开发、并在实践应用方面打下一定基础。

二、功能介绍1、管理员登陆功能。

2、注册管理员功能。

3、按照学生学号搜索学籍信息功能。

4、显示所有学生学籍信息功能。

5、添加新的学生学籍信息功能。

6、删除指定学生学籍功能。

┊┊┊┊┊┊┊┊┊┊┊┊┊装┊┊┊┊┊订┊┊┊┊┊线┊┊┊┊┊┊┊┊┊┊┊┊┊三、程序流程四、设计步骤1、运行程序,通过LoginFrame类的构造方法LoginFrame()调用init()来初始化,生成界面,如果4-1所示,输入用户名、密码,如果用户名密┊┊┊┊┊┊┊┊┊┊┊┊┊装┊┊┊┊┊订┊┊┊┊┊线┊┊┊┊┊┊┊┊┊┊┊┊┊码正确,显示提示登录成功,如图4-2所示图4-1 登录界面图4-2 登录成功核心代码://验证用户public boolean check(String u,String p){boolean b=false;try{ConnDB cd=new ConnDB();conn=cd.getConn();ps=(PreparedStatement) conn.prepareStatement("select userpwd from users where username='"+u+"'");res=ps.executeQuery();if(res.next()){┊┊┊┊┊┊┊┊┊┊┊┊┊装┊┊┊┊┊订┊┊┊┊┊线┊┊┊┊┊┊┊┊┊┊┊┊┊String dbpwd=res.getString(1);if(dbpwd.equals(p)){b=true;}}}catch(Exception e){e.printStackTrace();}finally{this.close();}return b;}2、登录成功后,进入管理界面,如图4-3所示,然后按照提示,输入要查找的学籍的学生学号,点击搜索按钮,响应搜索按钮的事件处理,调用actionPerformed(ActionEvent e)实现事件监听,然后在这个方法中调用DBOperate类,创建一个DBOperate类对象,调用DBOperate类的getAXueJiInfo(String tnum)方法,参数为学号,然后显示出所查找学生的学籍信息,如图4-4所示:图4-3 学生学籍管理系统主界面┊┊┊┊┊┊┊┊┊┊┊┊┊装┊┊┊┊┊订┊┊┊┊┊线┊┊┊┊┊┊┊┊┊┊┊┊┊图4-4 学生学籍管理系统主界面下的搜索界面核心代码://按学号查找学籍信息public xuejiBean getAXueJiInfo(String tnum){xuejiBean xjb=new xuejiBean();if(tnum.equals("")){return null;}int num=Integer.parseInt(tnum);try {ConnDB cd=new ConnDB();conn=cd.getConn();ps=(PreparedStatement) conn.prepareStatement("SELECT * FROM xueji WHERE num="+num+"");res=ps.executeQuery();while(res.next()){x jb.setNum(res.getInt(1));x jb.setSname(res.getString(2));x jb.setSex(res.getString(3));x jb.setMinzu(res.getString(4));x jb.setAge(res.getInt(5));x jb.setSdepart(res.getString(6));x jb.setStudytime(res.getString(7));x jb.setPface(res.getString(8));x jb.setAddress(res.getString(9));}} catch (Exception e) {e.printStackTrace();} finally{this.close();┊┊┊┊┊┊┊┊┊┊┊┊┊装┊┊┊┊┊订┊┊┊┊┊线┊┊┊┊┊┊┊┊┊┊┊┊┊}return xjb;}3、在管理界面的主界面中,点击搜索所有学籍信息,响应StuInfoFrame类中的actionPerformed(ActionEvent e)事件处理,然后在此方法中调用DBOperate类的ShowXueJiInfo()方法,然后在这个方法中查找数据库,将数据库返回的数据显示在JFrame中JTable内,显示结果如图4-5所示:图4-5 显示所有学生学籍信息的界面核心代码://显示所有学籍信息public ArrayList<xuejiBean> ShowXueJiInfo(){ArrayList<xuejiBean> al=new ArrayList<xuejiBean>();try {ConnDB cd=new ConnDB();conn=cd.getConn();ps=(PreparedStatement) conn.prepareStatement("SELECT * FROM xueji"); res=ps.executeQuery();while(res.next()){x uejiBean xjb=new xuejiBean();x jb.setNum(res.getInt(1));x jb.setSname(res.getString(2));x jb.setSex(res.getString(3));x jb.setMinzu(res.getString(4));x jb.setAge(res.getInt(5));x jb.setSdepart(res.getString(6));x jb.setStudytime(res.getString(7));x jb.setPface(res.getString(8));x jb.setAddress(res.getString(9));a l.add(xjb);}┊┊┊┊┊┊┊┊┊┊┊┊┊装┊┊┊┊┊订┊┊┊┊┊线┊┊┊┊┊┊┊┊┊┊┊┊┊} catch (Exception e) {e.printStackTrace();// TODO: handle exception} finally{this.close();}return al;}4、添加新的学生学籍信息,点击添加新学籍按钮响应StuInfoFrame类中的actionPerformed(ActionEvent e)事件处理,然后在此方法中,创建DBOperate类的实例,通过DBOperate类的实例调用putInforIntoDb(String name,String sex,String minzu,int age,Stringdepart,String time,String face,String address)方法将新学籍信息录入数据库中,效果如图4-6所示:图4-6 添加学生学籍界面核心代码://录入学籍信息public boolean putInforIntoDb(String name,String sex,String minzu,int age,String depart,String time,String face,String address){boolean b=false;try {ConnDB cd=new ConnDB();conn=cd.getConn();┊┊┊┊┊┊┊┊┊┊┊┊┊装┊┊┊┊┊订┊┊┊┊┊线┊┊┊┊┊┊┊┊┊┊┊┊┊ps=(PreparedStatement) conn.prepareStatement("INSERT INTO xueji (sname,sex,minzu,age,sdepart,studytime,pface,address) VALUES (?,?,?,?,?,?,?,?)");ps.setString(1, name);ps.setString(2, sex );ps.setString(3, minzu);ps.setInt(4, age);ps.setString(5, depart);ps.setString(6, time);ps.setString(7, face);ps.setString(8, address);int cont=ps.executeUpdate();if(cont==1){b=true;}} catch (Exception e) {e.printStackTrace();// TODO: handle exception} finally{this.close();}return b;}5、在2中,搜索出某个学生的学籍信息后,可以点击“删除该学籍信息”按钮,然后该按钮响应tuInfoFrame类中的actionPerformed(ActionEvente)事件处理通过在此方法中创建DBOperate类的实例来调用DBOperate类中的Deleteuser(String id)方法来删除该学籍信息。

java学生管理系统知识点

java学生管理系统知识点

java学生管理系统知识点学生管理系统是一个常见的软件应用程序,用于管理学校或教育机构中的学生信息和相关数据。

以下是关于Java学生管理系统的一些主要知识点:1. Java编程语言:学生管理系统是使用Java编写的,因此你需要掌握Java编程语言的基本语法、面向对象编程(OOP)概念、类和对象、继承、多态等。

2. 数据库操作:学生管理系统通常需要与数据库进行交互来存储和检索学生信息。

你需要学习和理解如何使用Java数据库连接(JDBC)来连接和操作数据库,如MySQL、Oracle等。

3. 用户界面设计:学生管理系统需要一个用户友好的界面来展示学生信息、添加、编辑和删除学生等操作。

你可以学习和使用Java图形用户界面(GUI)库,如Swing或JavaFX来设计和实现界面。

4. 文件操作:学生管理系统还可以支持从文件中读取和保存学生信息。

你需要学习如何使用Java的输入输出流(I/O)来读写文件,如文本文件或CSV文件。

5. 数据结构和算法:在学生管理系统中,你可能需要使用一些常见的数据结构和算法来处理学生信息,例如数组、链表、排序算法等。

了解和掌握这些基本的数据结构和算法对于设计和实现学生管理系统非常重要。

6. 错误处理和异常处理:在开发学生管理系统过程中,你需要了解如何处理可能发生的错误和异常情况,例如数据库连接失败、文件读取错误等。

学习Java中的异常处理机制可以帮助你编写更健壮的程序。

7. 安全性:学生管理系统通常涉及学生的个人信息,因此安全性是非常重要的。

你需要学习如何保护和处理敏感数据,如加密存储密码、防止SQL注入等安全措施。

以上是Java学生管理系统的一些主要知识点,希望对你有所帮助!如果有其他问题,请随时提问。

(完整版)学生信息管理系统数据库java

(完整版)学生信息管理系统数据库java

《数据库原理与应用》课程设计报告选题名称:学生信息管理系统组长:李盟指导教师:汤嘉立设计日期:2016.06.13——2016.06.24学号姓名小组评分教师评分2014144414 李盟902014144415 李玲902014144429 徐兰902014144431 许媛媛906.个人工作报告除上一步骤要求的完整文档外,每个人需陈述自己所承担的工作、在讨论中的个人见解,提供个人所承担工作的有关文档(可能是不完整的),并对个人的工作情况、收获等进行总结。

(1)承担的工作及贡献●需求分析阶段●概念模型设计阶段局部E-R模型:整体E-R模型:●逻辑模型设计阶段Student(sno,sn,sa,ss,sd)Course(cno,cn,pcno)Sc(sno,cno,g)Unpw(un,pw,qx)●物理模型设计阶段s(学生信息表)字段名称数据类型描述sno char (10) 学号,关键字sn char (20) 姓名sa int 年龄ss char (10) 性别sd char (10) 院系c(课程信息表)字段名称数据类型描述cno char (10) 课程号,关键字cn char (30) 课程名pcno char (10) 先行课程号sc(选课信息表)字段名称数据类型描述sno char (10) 学号,关键字cno char (10) 课程号,关键字g int 成绩unpw(用户信息表)字段名称数据类型描述un char (10) 用户名,关键字pw char (10) 密码qx int 角色1.视图:2.s(学生信息表)3.c(课程信息表)4.sc(选课信息表)5.unpw(用户信息表) 实施和实现阶段附件1 系统实施一、登录界面图片:代码:package li;import javax.swing.*;import java.awt.*;import java.awt.event.*;import java.sql.*;class DLFrame extends JFrame implements ActionListener, ItemListener {// 登录界面JPanel p1 = null;JPanel p2 = null;JPanel p3 = null;JLabel userName = new JLabel("用户:");JTextField txtUser = new JTextField();JLabel password = new JLabel("密码:");JPasswordField txtPwd = new JPasswordField(6);JLabel role = new JLabel("角色:");JComboBox cbrole = new JComboBox();JButton btnLogin = new JButton("登录");JButton btncz = new JButton("重置");JButton btnCancel = new JButton("取消");JLabel imageLabel;Icon image;static int OK = 1;static int CANCEL = 0;int actionCode = 0;Connection con = null;Statement stmt = null;ResultSet rs = null;int qxian = 0;public DLFrame() {// 构造方法super("登录界面");p1 = new JPanel();p2 = new JPanel();p3 = new JPanel();cbrole.addItem("管理员");cbrole.addItem("学生");image = new ImageIcon("Tulips.jpg");imageLabel = new JLabel(image);p1.add(imageLabel);this.setLayout(new FlowLayout());this.setBounds(100, 100, 246, 345);p2.setLayout(new GridLayout(4, 2));p2.add(userName);p2.add(txtUser);p2.add(password);p2.add(txtPwd);p2.add(role);p2.add(cbrole);p3.add(btnLogin);p3.add(btncz);p3.add(btnCancel);this.add(p1);this.add(p2);this.add(p3);this.setResizable(false);this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);this.show();btnLogin.addActionListener(this);cbrole.addItemListener(this);btncz.addActionListener(this);btnCancel.addActionListener(this);}public void connDB() { // 连接数据库try {Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");} catch (ClassNotFoundException e) {e.printStackTrace();}try {con = DriverManager.getConnection("jdbc:sqlserver://localhost:1433; DatabaseName=student","sa", "123");stmt = con.createStatement();} catch (SQLException e) {e.printStackTrace();}}public void closeDB() // 关闭连接{try {stmt.close();con.close();} catch (SQLException e) {e.printStackTrace();}}public void itemStateChanged(ItemEvent e) {if (e.getStateChange() == ItemEvent.SELECTED) {JComboBox jcb = (JComboBox) e.getSource();qxian = jcb.getSelectedIndex();}}public void actionPerformed(ActionEvent e) {Object source = e.getSource();String un = null;String pw = null;boolean success = false;// 用于判断是否登录成功if (source == btnLogin) {if (txtUser.getText().equals("") || txtPwd.getText().equals("")) {// 判断是否输入了用户名和密码JOptionPane.showMessageDialog(null, "登录名和密码不能为空!");} else {this.connDB();try {rs = stmt.executeQuery("select * from unpw where qx="+ qxian);while (rs.next()) {un = rs.getString("un").trim();pw = rs.getString("pw").trim();if (txtUser.getText().equals(un)) {if (txtPwd.getText().equals(pw)) {actionCode = OK;this.setVisible(false);if (qxian == 0) {new ManagerFrane();// 进入管理员界面}if (qxian == 1) {new StudentFrame();// 进入学生界面}success = true;break;} else {JOptionPane.showMessageDialog(null, "密码错误!");txtPwd.setText("");success = true;}}}if (!success) {JOptionPane.showMessageDialog(null, "登录名错误!");txtUser.setText("");txtPwd.setText("");}} catch (SQLException e1) {e1.printStackTrace();}}} else if (source == btncz) {txtUser.setText("");txtPwd.setText("");} else if (source == btnCancel) {System.exit(0);}}public static void main(String[] args){JPanel mainp=new JPanel();DLFrame student=new DLFrame();}}二、管理员界面图片:代码:package li;import java.awt.*;import java.awt.event.*;import javax.swing.*;class ManagerFrane extends JFrame implements ActionListener {// 管理员界面JPanel p1 = new JPanel();JPanel p2 = new JPanel();JButton btns = new JButton("学生信息管理");JButton btnc = new JButton("课程信息管理");JButton btnsc = new JButton("选课信息管理");JButton btng = new JButton("成绩信息管理");JButton btnu = new JButton("用户信息管理");JButton btnClose = new JButton("退出管理系统");JLabel l = new JLabel("管理员");ManagerFrane() {// 构造方法super("学生信息管理系统");setSize(350, 200);add("North", p1);add("Center", p2);p1.add(l);p2.add(btns);p2.add(btnc);p2.add(btnsc);p2.add(btng);p2.add(btnu);p2.add(btnClose);btns.addActionListener(this);btnc.addActionListener(this);btnsc.addActionListener(this);btng.addActionListener(this);btnu.addActionListener(this);btnClose.addActionListener(this);this.setResizable(false);this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);show();}public void actionPerformed(ActionEvent e) {if (e.getActionCommand() == "学生信息管理")new SM().display();if (e.getActionCommand() == "课程信息管理") {new CM("课程信息管理").display();}if (e.getActionCommand() == "选课信息管理") {new SCM("选课信息管理").display();}if (e.getActionCommand() == "成绩信息管理") {new GM("成绩信息管理").display();}if (e.getActionCommand() == "用户信息管理") {new PM("用户信息管理").display();}if (e.getActionCommand() == "退出管理系统") {System.exit(0);}}}(一)学生信息管理代码:class SM extends JFrame implements ActionListener {// 学生信息管理JPanel p = new JPanel();JButton btnAdd = new JButton("增加");JButton btnDelete = new JButton("删除");JButton btnAlter = new JButton("修改");JButton btnSearch = new JButton("查询");JButton btnDisplay = new JButton("显示");JMenuBar mb = new JMenuBar();JPanel p1 = new JPanel();;JTable sTable;JScrollPane scroll;Connection con = null;Statement stmt = null;ResultSet rs = null;Object[][] playerInfo;SSelect sst;String mxh = null;boolean bstd = false;SM() {// 构造方法super("学生信息管理");add("South", p);this.add("Center", p1);mb.add(btnAdd);mb.add(btnDelete);mb.add(btnAlter);mb.add(btnSearch);mb.add(btnDisplay);SM(SSelect sst) {// 构造方法super("学生信息管理");this.sst = sst;bstd = true;add("South", p);this.add("Center", p1);mb.add(btnAdd);mb.add(btnDelete);mb.add(btnAlter);mb.add(btnSearch);mb.add(btnDisplay);this.connDB();this.setBounds(200, 200, 400, 260);btnAdd.addActionListener(this);btnDelete.addActionListener(this);btnAlter.addActionListener(this);btnSearch.addActionListener(this);btnDisplay.addActionListener(this);this.setJMenuBar(mb);// this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);this.setResizable(false);show();}public void display() {// 显示所有学生的基本信息int i = 0;int j = 0;int k = 0;List al = new ArrayList();try {rs = stmt.executeQuery("select * from s");while (rs.next()) { // 找出表中的记录数赋给ial.add(rs.getString("sno"));al.add(rs.getString("sn"));al.add(rs.getString("ss"));al.add(rs.getInt("sa"));al.add(rs.getString("sd"));i++;}} catch (SQLException e) {e.printStackTrace();}playerInfo = new Object[i][5];String[] columnNames = { "学号", "姓名", "年龄", "性别", "院系" };try {rs = stmt.executeQuery("select * from s order by sno");while (rs.next()) {playerInfo[j][0] = rs.getString("sno");playerInfo[j][1] = rs.getString("sn");playerInfo[j][2] = rs.getInt("sa");playerInfo[j][3] = rs.getString("ss");playerInfo[j][4] = rs.getString("sd");j++;}} catch (SQLException e) {e.printStackTrace();}sTable = new JTable(playerInfo, columnNames);// 创建网格p1.add(sTable);scroll = new JScrollPane(sTable);this.add(scroll);}public void delete() {// 删除某个学生的基本信息String xh = null;String xm = null;int nl = 0;String xb = null;String yx = null;int row = -1;row = sTable.getSelectedRow();if (row == -1) {// 判断要删除的信息是否被选中JOptionPane.showMessageDialog(null, "请选择要删除的记录!");} else {if (!bstd) {// 判断选择的是不是查询后的结果int j1 = 0;try {rs = stmt.executeQuery("select * from s");while (rs.next() && j1 <= row) {// 找出当前被选中的记录在数据库中的对应xh = rs.getString("sno");xm = rs.getString("sn");nl = rs.getInt("sa");xb = rs.getString("ss");yx = rs.getString("sd");j1++;}} catch (SQLException e) {e.printStackTrace();}int i1 = 0;try {int rs1 = stmt.executeUpdate("delete from s where sno='"+ xh + "'"); // 删除数据库中当前被选中的记录stmt.executeUpdate("delete from unpw where un='" + xh + "'");// 删除对应的用户表中的记录JOptionPane.showMessageDialog(null, "记录删除成功!");this.dispose();new SM().display();} catch (SQLException e) {e.printStackTrace();}} else {try {int rs1 = stmt.executeUpdate("delete from s where sno='"+ mxh + "'");stmt.executeUpdate("delete from unpw where un='" + mxh+ "'");JOptionPane.showMessageDialog(null, "记录删除成功!");this.dispose();new SM().display();} catch (SQLException e) {e.printStackTrace();}}}}public void update() {// 修改某个学生的基本信息String xh = null;String xm = null;int nl = 0;String xb = null;String yx = null;int row = -1;row = sTable.getSelectedRow();if (row == -1) {JOptionPane.showMessageDialog(null, "请选择要修改的记录!");} else {int j1 = 0;try {if (!bstd) {// 判断选择的是不是查询后的结果rs = stmt.executeQuery("select * from s");} else {rs = stmt.executeQuery("select * from s where sno='" + mxh+ "'");}while (rs.next() && j1 <= row) {// 找出当前被选中的记录在数据库中的对应xh = rs.getString("sno");xm = rs.getString("sn");nl = rs.getInt("sa");xb = rs.getString("ss");yx = rs.getString("sd");j1++;}} catch (SQLException e) {e.printStackTrace();}SAdd sadd = new SAdd(xb, yx);sadd.setTitle("修改");sadd.tsno.setText(xh);sadd.tsname.setText(xm);sadd.tsage.setText("" + nl);sadd.tsno.setEnabled(false);this.dispose();}}public void select() {// 显示某个查询的结果mxh = sst.xh;playerInfo = new Object[1][5];String[] columnNames = { "学号", "姓名", "年龄", "性别", "院系" };try {rs = stmt.executeQuery("select * from s where sno='" + mxh + "'");while (rs.next()) {playerInfo[0][0] = rs.getString("sno");playerInfo[0][1] = rs.getString("sn");playerInfo[0][2] = rs.getInt("sa");playerInfo[0][3] = rs.getString("ss");playerInfo[0][4] = rs.getString("sd");}} catch (SQLException e) {e.printStackTrace();}if (playerInfo[0][1] == null) {this.dispose();JOptionPane.showMessageDialog(null, "学号不存在!");new SM().display();} else {sTable = new JTable(playerInfo, columnNames);// 创建网格p1.add(sTable);scroll = new JScrollPane(sTable);this.add(scroll);}}public void actionPerformed(ActionEvent e) {if (e.getActionCommand() == "增加") {new SAdd("男", "计科系");this.dispose();}if (e.getActionCommand() == "删除") {this.delete();}if (e.getActionCommand() == "修改") {this.update();}if (e.getActionCommand() == "查询") {sst = new SSelect("学号:");this.dispose();}if (e.getActionCommand() == "显示") {this.dispose();new SM().display();}}}1.用于学生信息管理中增加或修改某条记录的界面图片:代码:class SAdd extends JFrame implements ActionListener, ItemListener {// 用于学生信息管理中增加或修改某条记录的界面JLabel lsno = new JLabel("学号:");JLabel lsname = new JLabel("姓名:");JLabel lssex = new JLabel("性别:");JLabel lsage = new JLabel("年龄:");JLabel lsdept = new JLabel("院系:");JTextField tsno = new JTextField(14);JTextField tsname = new JTextField(14);JComboBox cbssex = new JComboBox();JTextField tsage = new JTextField(14);JComboBox cbsdept = new JComboBox();JButton btnOK = new JButton(" 确定"); JButton btnCancel = new JButton(" 取消"); JPanel p = new JPanel();Connection con = null;Statement stmt = null;ResultSet rs = null;String xb = "男";String yx = "计科系";boolean isNewsm = true;// 用于判断是否显示学生管理的界面public SAdd(String xb, String yx) {// 构造方法this.xb = xb;this.yx = yx;this.setTitle("增加");this.setBounds(200, 200, 220, 210);if (xb.trim().equals("男")) {cbssex.addItem("男");cbssex.addItem("女");} else {cbssex.addItem("女");cbssex.addItem("男");}if (yx.trim().equals("计科系")) {cbsdept.addItem("计科系");cbsdept.addItem("物理系");cbsdept.addItem("数学系");cbsdept.addItem("外语系");}if (yx.trim().equals("物理系")) {cbsdept.addItem("物理系");cbsdept.addItem("计科系");cbsdept.addItem("数学系");cbsdept.addItem("外语系");}if (yx.trim().equals("外语系")) {cbsdept.addItem("外语系");cbsdept.addItem("计科系");cbsdept.addItem("物理系");cbsdept.addItem("数学系");}if (yx.trim().equals("数学系")) {cbsdept.addItem("数学系");cbsdept.addItem("计科系");cbsdept.addItem("物理系");cbsdept.addItem("外语系");}p.setLayout(new FlowLayout(FlowLayout.LEFT));p.add(lsno);p.add(tsno);p.add(lsname);p.add(tsname);p.add(lsage);p.add(tsage);p.add(lssex);p.add(cbssex);p.add(lsdept);p.add(cbsdept);p.add(btnOK);p.add(btnCancel);this.add(p);this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);cbssex.addItemListener(this);cbsdept.addItemListener(this);btnOK.addActionListener(this);btnCancel.addActionListener(this);this.show();}public void insertst() { // 插入记录String xh = null;String xm = null;int nl = 0;xh = tsno.getText();xm = tsname.getText();try {nl = Integer.parseInt((String) tsage.getText());if (this.getTitle() == "修改") {// 如果是修改记录,先删除再增加try {this.connDB();int rs1 = stmt.executeUpdate("delete from s where sno='"+ xh + "'");} catch (SQLException e) {e.printStackTrace();}}String str = "insert into s values('" + xh + "','" + xm + "'," + nl+ ",'" + xb + "','" + yx + "')";this.connDB();// 连接数据库try {stmt.executeUpdate(str);JOptionPane.showMessageDialog(null, this.getTitle() + "成功!","提示", RMATION_MESSAGE, new ImageIcon("menu4.gif"));this.setVisible(false);} catch (SQLException e) {JOptionPane.showMessageDialog(null, "学号已存在!");tsno.setText("");}} catch (NumberFormatException e) {// 判断年龄是否为数字JOptionPane.showMessageDialog(null, "年龄必须是整数!");tsage.setText("");isNewsm = false;}if (this.getTitle() == "增加") {// 如果是增加记录,对应的用户表中也增加一条记录try {stmt.executeUpdate("insert into unpw values('" + xh + "','"+ xh + "'," + 1 + ")");} catch (NullPointerException e) {} catch (SQLException e) {// e.printStackTrace();}}}public void actionPerformed(ActionEvent e) {if (e.getActionCommand() == " 确定") {this.insertst();if (isNewsm) {new SM().display();}isNewsm = true;}if (e.getActionCommand() == " 取消") {this.setVisible(false);new SM().display();}}public void itemStateChanged(ItemEvent e) { // 下拉框的监听if (e.getStateChange() == ItemEvent.SELECTED) {JComboBox jcb = (JComboBox) e.getSource();if ((jcb.getSelectedItem() == "男")|| (jcb.getSelectedItem() == "女")) {xb = (String) jcb.getSelectedItem();} else {yx = (String) jcb.getSelectedItem();}}}}2.用于学生基本信息管理中查询时输入学号的界面图片:代码:public class SSelect extends JFrame implements ActionListener {// 用于学生基本信息管理中查询时输入学号的界面JLabel ltitle = null;JTextField tsno = new JTextField(8);JButton btnOK = new JButton("确定");JPanel p = new JPanel();String xh = null;public SSelect(String str) {// 构造方法ltitle = new JLabel(str);p.add(ltitle);p.add(tsno);p.add(btnOK);add(p);this.setBounds(300, 280, 200, 160);btnOK.addActionListener(this);this.setResizable(false);this.show();}public void actionPerformed(ActionEvent e) {xh = tsno.getText();// 取得当前输入学号的值if (xh.equals("")) {// 判断是否输入了学号JOptionPane.showMessageDialog(null, "学号不能为空,请重新输入!");} else {this.dispose();new SM(this).select();}}}(二)课程信息管理图片:代码:class CM extends JFrame implements ActionListener {// 课程信息管理JPanel p = new JPanel();JButton btnAdd = new JButton("增加");JButton btnDelete = new JButton("删除");JButton btnAlter = new JButton("修改");JButton btnSearch = new JButton("查询");JButton btnDisplay = new JButton("显示");JMenuBar mb = new JMenuBar();JPanel p1 = new JPanel();;JTable sTable;JScrollPane scroll;Connection con = null;Statement stmt = null;ResultSet rs = null;Object[][] playerInfo;CSelect cst;String mkch = null;boolean bstd = false;CM(String title) {// 构造方法super(title);add("South", p);this.add("Center", p1);mb.add(btnAdd);mb.add(btnDelete);mb.add(btnAlter);mb.add(btnSearch);mb.add(btnDisplay);CM(CSelect cst, String title) {// 构造方法super(title);this.cst = cst;bstd = true;add("South", p);this.add("Center", p1);mb.add(btnAdd);mb.add(btnDelete);mb.add(btnAlter);mb.add(btnSearch);mb.add(btnDisplay);this.connDB();this.setBounds(200, 200, 400, 260);btnAdd.addActionListener(this);btnDelete.addActionListener(this);btnAlter.addActionListener(this);btnSearch.addActionListener(this);btnDisplay.addActionListener(this);this.setJMenuBar(mb);// this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);this.setResizable(false);show();}public void display() {// 显示所有的课程信息int i = 0;int j = 0;int k = 0;List al = new ArrayList();try {rs = stmt.executeQuery("select * from c");while (rs.next()) {// 找出表中的记录数赋给ial.add(rs.getString("cno"));al.add(rs.getString("cn"));al.add(rs.getString("pcno"));i++;}} catch (SQLException e) {e.printStackTrace();}playerInfo = new Object[i][3];String[] columnNames = { "课程号", "课程名", "先行课程号" };try {rs = stmt.executeQuery("select * from c order by cno");while (rs.next()) {playerInfo[j][0] = rs.getString("cno");playerInfo[j][1] = rs.getString("cn");playerInfo[j][2] = rs.getString("pcno");j++;}} catch (SQLException e) {e.printStackTrace();}sTable = new JTable(playerInfo, columnNames);// 创建网格p1.add(sTable);scroll = new JScrollPane(sTable);this.add(scroll);}public void connDB() { // 连接数据库try {Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");} catch (ClassNotFoundException e) {e.printStackTrace();}try {con = DriverManager.getConnection("jdbc:sqlserver://localhost:1433; DatabaseName=student","sa", "123");stmt = con.createStatement();} catch (SQLException e) {e.printStackTrace();}}public void closeDB() // 关闭连接{try {stmt.close();con.close();} catch (SQLException e) {e.printStackTrace();}}public void delete() {// 删除某个课程信息String kch = null;String kcm = null;String xxkch = null;int row = -1;row = sTable.getSelectedRow();if (row == -1) {// 判断要删除的信息是否被选中JOptionPane.showMessageDialog(null, "请选择要删除的记录!");} else {if (!bstd) {// 判断选择的是不是查询后的结果int j1 = 0;try {rs = stmt.executeQuery("select * from c");while (rs.next() && j1 <= row) {// 找出当前被选中的记录在数据库中的对应kch = rs.getString("cno");kcm = rs.getString("cn");xxkch = rs.getString("pcno");j1++;}} catch (SQLException e) {e.printStackTrace();}int i1 = 0;try {int rs1 = stmt.executeUpdate("delete from c where cno='"+ kch + "'");// 删除数据库中当前被选中的记录JOptionPane.showMessageDialog(null, "记录删除成功!");this.dispose();new CM("课程信息管理").display();} catch (SQLException e) {e.printStackTrace();}} else {try {int rs1 = stmt.executeUpdate("delete from c where cno='"+ mkch + "'");// 删除数据库中当前被选中的记录JOptionPane.showMessageDialog(null, "记录删除成功!");this.dispose();new CM("课程信息管理").display();} catch (SQLException e) {e.printStackTrace();}}}}public void update() {// 修改某个课程记录String kch = null;String kcm = null;String xxkch = null;int row = -1;row = sTable.getSelectedRow();if (row == -1) {JOptionPane.showMessageDialog(null, "请选择要修改的记录!");} else {int j1 = 0;try {if (!bstd) {// 判断选择的是不是查询后的结果rs = stmt.executeQuery("select * from c");} else {rs = stmt.executeQuery("select * from c where cno='" + mkch+ "'");}while (rs.next() && j1 <= row) {// 找出当前被选中的记录在数据库中的对应kch = rs.getString("cno");kcm = rs.getString("cn");xxkch = rs.getString("pcno");j1++;}} catch (SQLException e) {e.printStackTrace();}CAdd cadd = new CAdd();cadd.setTitle("修改");cadd.tcno.setText(kch);cadd.tcname.setText(kcm);cadd.tpcno.setText(xxkch);cadd.tcno.setEnabled(false);this.dispose();}}public void select() {// 显示某个查询的结果mkch = cst.kch;playerInfo = new Object[1][3];String[] columnNames = { "课程号", "课程名", "先行课程号" };try {rs = stmt.executeQuery("select * from c where cno='" + mkch + "'");while (rs.next()) {playerInfo[0][0] = rs.getString("cno");playerInfo[0][1] = rs.getString("cn");playerInfo[0][2] = rs.getString("pcno");}} catch (SQLException e) {e.printStackTrace();}if (playerInfo[0][1] == null) {this.dispose();JOptionPane.showMessageDialog(null, "课程号不存在!");new CM("课程信息管理").display();} else {sTable = new JTable(playerInfo, columnNames);// 创建网格p1.add(sTable);scroll = new JScrollPane(sTable);this.add(scroll);}}public void actionPerformed(ActionEvent e) {if (e.getActionCommand() == "增加") {new CAdd();this.dispose();}if (e.getActionCommand() == "删除") {this.delete();}if (e.getActionCommand() == "修改") {this.update();}if (e.getActionCommand() == "查询") {cst = new CSelect();this.dispose();}if (e.getActionCommand() == "显示") {this.dispose();new CM("课程信息管理").display();}}}3.用于课程信息管理中增加或修改某条记录的界面图片:代码:class CAdd extends JFrame implements ActionListener{// 用于课程信息管理中增加或修改某条记录的界面JLabel lcno = new JLabel("课程号:");JLabel lcname = new JLabel("课程名:");JLabel lpcno = new JLabel("先行课程号:");JTextField tcno = new JTextField(10);JTextField tcname = new JTextField(10);JTextField tpcno = new JTextField(10);JButton btnOK = new JButton("确定");JButton btnCancel = new JButton("取消");JPanel p = new JPanel();Connection con = null;Statement stmt = null;ResultSet rs = null;boolean isNewsm = true;// 用于判断是否显示课程信息管理的界面public CAdd() {// 构造方法this.setTitle("增加");this.setBounds(200, 200, 146, 235);p.setLayout(new FlowLayout(FlowLayout.LEFT));p.add(lcno);p.add(tcno);p.add(lcname);p.add(tcname);p.add(lpcno);p.add(tpcno);p.add(btnOK);p.add(btnCancel);this.add(p);this.setResizable(false);this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);btnOK.addActionListener(this);btnCancel.addActionListener(this);this.show();}public void insertst() { // 插入记录String kch = null;String kcm = null;String xxkch=null;kch = tcno.getText();kcm = tcname.getText();xxkch=tpcno.getText();if (this.getTitle() == "修改") {// 如果是修改记录,先删除再增加try {this.connDB();int rs1 = stmt.executeUpdate("delete from c where cno='"+ kch + "'");} catch (SQLException e) {e.printStackTrace();}}String str = "insert into c values('" + kch + "','" + kcm + "','"+ xxkch + "')";public void actionPerformed(ActionEvent e) {if (e.getActionCommand() == "确定") {this.insertst();if (isNewsm) {new CM("课程信息管理").display();}isNewsm = true;}if (e.getActionCommand() == "取消") {this.setVisible(false);new CM("课程信息管理").display();}}}4.用于课程信息管理中查询时输入课程号的界面图片:代码:public class CSelect extends JFrame implements ActionListener {// 用于课程信息管理中查询时输入课程号的界面JLabel ltitle = new JLabel("课程号:");JTextField tcno = new JTextField(8);JButton btnOK = new JButton("确定");JPanel p = new JPanel();String kch = null;public CSelect() { // 构造方法p.add(ltitle);p.add(tcno);p.add(btnOK);add(p);this.setBounds(300, 280, 200, 160);btnOK.addActionListener(this);this.setResizable(false);this.show();}public void actionPerformed(ActionEvent e) {kch = tcno.getText();// 取得当前输入课程号的值if (kch.equals("")) {// 判断是否输入了课程号JOptionPane.showMessageDialog(null, "课程号不能为空,请重新输入!");} else {this.dispose();new CM(this, "课程信息管理").select();}}}(三)选课信息管理图片:代码:。

java学生管理系统知识点

java学生管理系统知识点

java学生管理系统知识点Java学生管理系统是一种用Java语言开发的学生信息管理系统,主要用于对学生的基本信息、课程信息、成绩信息等进行管理和查询。

Java学生管理系统的开发需要掌握一些基本的知识点和技术。

本文将从以下几个方面介绍Java学生管理系统的相关知识点。

一、Java基础知识1. Java语言特点:Java是一种跨平台的高级编程语言,具有面向对象、简单易学、安全可靠等特点。

2. Java基本语法:包括变量、数据类型、运算符、流程控制语句、数组、类与对象等基本语法知识。

3. 面向对象编程:掌握类和对象的概念,理解封装、继承、多态等面向对象的特性。

二、数据库知识1. 关系型数据库:了解关系型数据库的基本概念和常用操作,如创建表、插入数据、更新数据、删除数据等。

2. SQL语句:熟悉SQL语句的使用,包括查询语句、更新语句、删除语句等。

3. 数据库连接:掌握Java与数据库的连接方式,如JDBC等技术。

三、图形用户界面(GUI)开发1. Swing组件库:了解Swing组件库的使用,如窗口、按钮、文本框等,实现用户界面的创建和交互。

2. 事件处理:掌握事件的概念和处理方式,如按钮点击事件、菜单选择事件等。

四、文件操作1. 文件读写:掌握Java文件读写的基本操作,包括文件的打开、读取、写入和关闭等。

2. 文件路径:了解文件路径的表示方式,包括绝对路径和相对路径等。

五、系统设计与架构1. 模块划分:合理划分系统的功能模块,如学生信息管理模块、课程信息管理模块、成绩信息管理模块等。

2. 数据库设计:设计合理的数据库结构,包括学生信息表、课程信息表、成绩信息表等。

3. 系统架构:设计系统的整体架构,包括前端界面的设计、后端逻辑的实现等。

六、系统测试与维护1. 单元测试:编写单元测试代码,对系统的各个模块进行测试,保证系统的功能正常。

2. 故障排除:定位和修复系统中的故障和问题,确保系统的稳定性和可靠性。

java学生学籍管理系统培训资料

java学生学籍管理系统培训资料

学生学籍管理系统//存放基本信息的散列表//存放散列表的文件//卡片布局主类;import java.awt.*;import java.awt.eve nt.*; import javax.swi ng.*; import java.io.*;import java.util.Hashtable;public class Stude ntMa nager exte nds JFrame impleme nts Actio nListe ner{Stude "Situation 基本信息录入=nu II; ModifySituati on 基本信息修改=n ull; In quest 基本信息查询=n ull; Delete基本信息删除=n ull;JMen uBar bar; JMe nu fileMe nu;JMe nultem 录入修改,查询删除; Container con=n ull; Hashtable 基本信息=n ull; File file=nu II;CardLayout card=nu II; JLabel label=n ull; JPa nel pCe nter;public Stude ntMa nager (){录入=new JMenultem (”录入学生基本信息”); 修改=new JMenultem (”修改学生基本信息”); 查询=new JMenultem (”查询学生基本信息”);删除=new JMenultem (”删除学生基本信息"); bar=new JMe nuBar (); fileMenu=new JMenu (” 菜单选项"); fileMe nu.add (录入); fileMe nu.add (修改);fileMe nu.add(查询);fileMe nu.add(删除);bar.add(fileMe nu);setJMe nuBar(bar);label=new JLabel("欢迎使用学生基本信息管理系统"JLabel.CENTER);label.setFont(new Font(” TimesRoman",Font.BOLD,24));label.setForegro un d(Color.red);基本信息=new Hashtable();录入.addActio nListe ner(this);修改.addActio nListe ner(this);查询.addActionListener(this);删除.addActio nListe ner(this);card=new CardLayout(); con=getC onten tPa ne(); pCe nter=new JPanel(); pCe nter.setLayout(card);file=new File("基本信息.txt");if(!file.exists()){try{FileOutputStream out=new FileOutputStream(file);ObjectOutputStream objectOut=new ObjectOutputStream(out);objectOut.writeObject(基本信息);objectOut.close(); out.close();} catch(IOExcepti on e){}}基本信息录入=new StudentSituation(file);基本信息修改=new ModifySituatio n(file);JFrame f=new JFrame();基本信息查询=new In quest(f,file);基本信息删除=new Delete(file);pCenter.add(欢迎语界面",label);pCenter.add('录入界面",基本信息录入);pCenter.add(修改界面",基本信息修改);pCenter.add(删除界面",基本信息删除);co n.add(pCe nter,BorderLayout.CENTER);con. validate。

Java程序设计课程设计---学生学籍管理系统

Java程序设计课程设计---学生学籍管理系统

Java程序设计课程设计课程名称Java程序设计课程设计课程编号学号学生姓名所在专业所在班级指导教师成绩教师签字目录设计总说明 --------------------------------------------------------------II 1. 课程设计目的与需求分析 ------------------------------------------------3 1.1 课程设计目的 ------------------------------------------------------31.2 需求分析 ----------------------------------------------------------32. 设计思路与主功能设计 --------------------------------------------------4 2.1 设计思路 ----------------------------------------------------------4 2.1.1 开发环境和软件 ------------------------------------------------42.1.2 数据库表结构 --------------------------------------------------42.1.3 程序设计图 ----------------------------------------------------42.2 功能设计与介绍 ----------------------------------------------------53. 具体功能的介绍和数据测试 ----------------------------------------------5 3.1 登录界面 ----------------------------------------------------------5 3.2 主功能界面 --------------------------------------------------------7 3.2.1 查询 ----------------------------------------------------------7 3.2.2 添加 ----------------------------------------------------------9 3.2.3 修改 ---------------------------------------------------------10 3.2.4 删除 ---------------------------------------------------------12 3.2.5 关于 ---------------------------------------------------------133.2.6 退出 ---------------------------------------------------------134. 课程设计总结 ---------------------------------------------------------145. 附录(程度代码) -------------------------------------------------------15设计总说明1.设计概况名称:学生学籍管理系统用途:学校等机构功能:实现对学生学籍信息的管理与维护等功能2.设计说明学生学籍管理系统,可用于学校等机构的学生信息管理,查询,更新与维护,使用方便,易用性强,图形界面清晰明了。

java学生管理系统综合实训手册

java学生管理系统综合实训手册

java学生管理系统综合实训手册一、实训目标通过本次实训,学生应能够:1.掌握面向对象的程序设计方法,了解Java语言的基本语法和常用类库。

2.熟悉Java的图形用户界面设计和事件处理。

3.能够利用Java实现学生信息的录入、查询、修改和删除等功能。

4.能够理解并应用数据结构算法实现对学生信息的排序、查找和统计等操作。

5.具备良好的编码规范与注释习惯,能够进行模块化拓展和代码复用。

二、实训内容本次实训的主要内容为实现一个基本的学生管理系统,包括以下功能:1.学生信息的录入:从键盘中输入学生的基本信息(学号、姓名、性别、年龄等),并将其保存到文件或数据库中。

2.学生信息的查询:根据学号或姓名等条件进行学生信息的查询,并将结果显示在界面上。

3.学生信息的修改:根据学号或姓名等条件对学生信息进行修改,并将修改后的信息保存到文件或数据库中。

4.学生信息的删除:根据学号或姓名等条件进行学生信息的删除,并将删除后的信息保存到文件或数据库中。

5.学生信息的排序:按学号或姓名等条件对学生信息进行排序,并将排序结果显示在界面上。

6.学生信息的统计:对学生信息进行统计分析,如计算平均成绩、总分等,并将统计结果显示在界面上。

三、实训步骤1.需求分析与设计:根据系统功能需求,进行系统设计与界面设计。

2.环境搭建:安装并配置Java开发环境,如JDK、Eclipse等。

3.界面设计与实现:使用Java的图形用户界面库,设计并实现系统的主界面和相关界面。

4.业务逻辑设计与实现:根据需求,设计并实现系统的业务逻辑,包括学生信息的录入、查询、修改、删除等功能。

5.数据存储与操作:选择合适的数据存储方式(如文件、数据库等),并实现对学生信息的存储和操作。

6.功能测试与调试:对系统进行功能测试,检查并修复可能存在的问题和错误。

7.性能优化与扩展:对系统进行性能优化,确保系统能够处理大量数据和复杂操作。

8.文档编写与总结:编写实训手册和项目文档,总结并反思本次实训的收获和经验。

学生信息管理系统数据库java完整版

学生信息管理系统数据库java完整版

学生信息管理系统数据库j a v aHEN system office room 【HEN16H-HENS2AHENS8Q8-HENH1688】《数据库原理与应用》课程设计报告选题名称:学生信息管理系统组长:李盟指导教师:汤嘉立设计日期:——2.课程设计内容:(1)数据库设计教师讲解数据库的设计方法以及PowerDesigner的使用,学生自选题目,要求学生根据题目的需求描述,进行实际调研,提出完整的需求分析报告、用PowerDesigner建立概念模型、逻辑模型、物理模型。

在物理模型中根据需要添加必要的约束、视图、触发器和存储过程等数据库对象,最后生成创建数据库的脚本,提出物理设计的文档。

要求学生提交的报告包含:需求说明书概念数据模型(E-R数据模型)逻辑数据模型(含关系规范化)物理数据模型(含约束、视图、触发器、存储过程、安全设计、恢复方案、事务设计等等)创建数据库的脚本(数据库对象的定义语言)物理设计的文档(数据库的实施规划)6.个人工作报告除上一步骤要求的完整文档外,每个人需陈述自己所承担的工作、在讨论中的个人见解,提供个人所承担工作的有关文档(可能是不完整的),并对个人的工作情况、收获等进行总结。

(1)承担的工作及贡献需求分析阶段概念模型设计阶段局部E-R模型:整体E-R模型:逻辑模型设计阶段Student(sno,sn,sa,ss,sd)Course(cno,cn,pcno)Sc(sno,cno,g)Unpw(un,pw,qx)物理模型设计阶段s(学生信息表)字段名称数据类型描述sno char (10)学号,关键字sn char (20)姓名sa int年龄ss char (10)性别sd char (10)院系c(课程信息表)字段名称数据类型描述cno char (10)课程号,关键字cn char (30)课程名pcno char (10)先行课程号sc(选课信息表)字段名称数据类型描述sno char (10)学号,关键字cno char (10)课程号,关键字g int成绩unpw(用户信息表)字段名称数据类型描述un char (10)用户名,关键字pw char (10)密码qx int角色1.视图:2.s(学生信息表)3.c(课程信息表)4.sc(选课信息表)5.unpw(用户信息表)实施和实现阶段详细见附件1。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

j a v a学生学籍管理系统主类;import java.awt.*;import java.awt.event.*;import javax.swing.*;import java.io.*;import java.util.Hashtable;public class StudentManager extends JFrame implements ActionListener{ StudentSituation 基本信息录入=null;ModifySituation 基本信息修改=null;Inquest 基本信息查询=null;Delete 基本信息删除=null;JMenuBar bar;JMenu fileMenu;JMenuItem 录入,修改,查询,删除;Container con=null;Hashtable 基本信息=null; //存放基本信息的散列表File file=null; //存放散列表的文件CardLayout card=null; //卡片布局JLabel label=null;JPanel pCenter;public StudentManager(){录入=new JMenuItem("录入学生基本信息");修改=new JMenuItem("修改学生基本信息");查询=new JMenuItem("查询学生基本信息");删除=new JMenuItem("删除学生基本信息");bar=new JMenuBar();fileMenu=new JMenu("菜单选项");fileMenu.add(录入);fileMenu.add(修改);fileMenu.add(查询);fileMenu.add(删除);bar.add(fileMenu);setJMenuBar(bar);label=new JLabel("欢迎使用学生基本信息管理系统",JLabel.CENTER);label.setFont(new Font(" TimesRoman",Font.BOLD,24));label.setForeground(Color.red);基本信息=new Hashtable();录入.addActionListener(this);修改.addActionListener(this);查询.addActionListener(this);删除.addActionListener(this);card=new CardLayout();con=getContentPane();pCenter=new JPanel();pCenter.setLayout(card);file=new File("基本信息.txt");if(!file.exists()){try{FileOutputStream out=new FileOutputStream(file);ObjectOutputStream objectOut=new ObjectOutputStream(out);objectOut.writeObject(基本信息);objectOut.close();out.close();}catch(IOException e){}}基本信息录入=new StudentSituation(file);基本信息修改=new ModifySituation(file);JFrame f=new JFrame();基本信息查询=new Inquest(f,file);基本信息删除=new Delete(file);pCenter.add("欢迎语界面",label);pCenter.add("录入界面",基本信息录入);pCenter.add("修改界面",基本信息修改);pCenter.add("删除界面",基本信息删除);con.add(pCenter,BorderLayout.CENTER);con.validate();addWindowListener(new WindowAdapter(){public void windowClosing(WindowEvent e){System.exit(0);}});setVisible(true);setBounds(100,50,420,380);validate();}public void actionPerformed(ActionEvent e){if(e.getSource()==录入){card.show(pCenter,"录入界面");}else if(e.getSource()==修改){card.show(pCenter,"修改界面");}else if(e.getSource()==查询){基本信息查询.setVisible(true);//基本信息查询查询窗口设置为独立,便于用户查询}else if(e.getSource()==删除){card.show(pCenter,"删除界面");}}public static void main(String args[]){new StudentManager();}}录入界面:import java.awt.*;import java.awt.event.*;import javax.swing.*;import java.io.*;import java.util.*;@SuppressWarnings("unchecked") public class StudentSituation extends JPanel implements ActionListener{Hashtable 基本信息表=null; //存放学生基本信息的散列表JTextField 学号,姓名,专业,年级,出生;JRadioButton 男,女;Student 学生=null;ButtonGroup group=null;JButton 录入,重置;FileInputStream inOne=null;ObjectInputStream inTwo=null;FileOutputStream outOne=null;ObjectOutputStream outTwo=null;File file=null;public StudentSituation(File file){this.file=file;学号=new JTextField(10);姓名=new JTextField(10);专业=new JTextField(10);年级=new JTextField(10);出生=new JTextField(10);group=new ButtonGroup();男=new JRadioButton("男",true);女=new JRadioButton("女",false);group.add(男);group.add(女);录入=new JButton("录入");重置=new JButton("重置");录入.addActionListener(this);重置.addActionListener(this);Box box1=Box.createHorizontalBox();box1.add(new JLabel("学号:",JLabel.CENTER)); box1.add(学号);Box box2=Box.createHorizontalBox();box2.add(new JLabel("姓名:",JLabel.CENTER)); box2.add(姓名);Box box3=Box.createHorizontalBox();box3.add(new JLabel("性别:",JLabel.CENTER)); box3.add(男);box3.add(女);Box box4=Box.createHorizontalBox();box4.add(new JLabel("专业:",JLabel.CENTER));box4.add(专业);Box box5=Box.createHorizontalBox();box5.add(new JLabel("年级:",JLabel.CENTER));box5.add(年级);Box box6=Box.createHorizontalBox();box6.add(new JLabel("出生:",JLabel.CENTER));box6.add(出生);Box boxH=Box.createVerticalBox(); //创建一个垂直的box容器,其中从上向下排列//6个水平box容器boxH.add(box1);boxH.add(box2);boxH.add(box3);boxH.add(box4);boxH.add(box5);boxH.add(box6);boxH.add(Box.createVerticalGlue());//垂直box容器内的组件靠上对齐JPanel pCenter=new JPanel();pCenter.add(boxH);setLayout(new BorderLayout());add(pCenter,BorderLayout.CENTER);JPanel pSouth=new JPanel();pSouth.add(录入);pSouth.add(重置);add(pSouth,BorderLayout.SOUTH);validate();}public void actionPerformed(ActionEvent e){if(e.getSource()==录入){String number="";number=学号.getText();if(number.length()>0){try{inOne=new FileInputStream(file);inTwo=new ObjectInputStream(inOne);基本信息表=(Hashtable)inTwo.readObject();//首先到文件中读取hashtable对象inOne.close();inTwo.close();}catch(Exception ee){}if(基本信息表.containsKey(number)){//如果该生学号对应的基本信息已经存在,弹出对话框String warning="该生基本信息已存在,请到修改页面修改!";JOptionPane.showMessageDialog(this,warning,"警告",JOptionPane.WARNING_MESSAGE);}else{String m="基本信息将录入";intok=JOptionPane.showConfirmDialog(this,m,"确认",JOptionPane.YES_NO_OPTION,RMATION_MESSAGE);if(ok==JOptionPane.YES_OPTION){String name=姓名.getText();String discipling=专业.getText();String grade=年级.getText();String borth=出生.getText();String sex=null;if(男.isSelected()){sex=男.getText();}else{sex=女.getText();}学生=new Student();学生.setNumber(number);学生.setName(name);学生.setDiscipling(discipling);学生.setGrade(grade);学生.setBorth(borth);学生.setSex(sex);try{outOne=new FileOutputStream(file);outTwo=new ObjectOutputStream(outOne);基本信息表.put(number,学生);outTwo.writeObject(基本信息表);outTwo.close();outOne.close();学号.setText(null);姓名.setText(null);专业.setText(null);年级.setText(null);出生.setText(null);}catch(Exception ee){System.out.println(ee);}}}}else{String warning="必须输入学号";JOptionPane.showMessageDialog(this,warning,"警告",JOptionPane.WARNING_MESSAGE);}}if(e.getSource()==重置){学号.setText(null);姓名.setText(null);专业.setText(null);年级.setText(null);出生.setText(null);}}}查询界面:import java.awt.*;import java.awt.event.*;import javax.swing.*;import java.io.*;import java.util.*;public class Inquest extends JDialog implements ActionListener{ Hashtable 基本信息表=null;JTextField 学号,姓名,专业,年级,出生;JRadioButton 男,女;JButton 查询;ButtonGroup group=null;FileInputStream inOne=null;ObjectInputStream inTwo=null; File file=null;public Inquest(JFrame f,File file){ super(f,"查询对话框",false);this.file=file;学号=new JTextField(11);查询=new JButton("查询");学号.addActionListener(this);查询.addActionListener(this);姓名=new JTextField(10);姓名.setEditable(false);专业=new JTextField(10);专业.setEditable(false);年级=new JTextField(10);年级.setEditable(false);出生=new JTextField(10);出生.setEditable(false);男=new JRadioButton("男",false);女=new JRadioButton("女",false);group=new ButtonGroup();group.add(男);group.add(女);Box box1=Box.createHorizontalBox();//以下创建6个水平box容器,容器内从左向右排列组件。

相关文档
最新文档