编程管理学生数据。要求: 1. 自选数据库管理系统创建数据库stu,按照下表的结构创建"student"表: 字段名 Java数据类型 宽度 SQL数据类型 id int 10 int Name String 20 Char(20) Sex String 2 Char(2) Age Int 3 Integer 假设表中已有3个学生的数据: id Name Sex Age 1 张小明 男 18 2 李雷 男 19 3 韩梅梅 女 18 2. 设计图形用户界面,通过事件处理实现学生数据管理功能。 3. 用恰当的方法处理可能出现的异常。 4. 将数据表stu及其数据操作封装成类,将数据操作功能封装成类的方法,通过该类,借助图形用户界面实现下面功能: (1)向表中增加记录并显示增加后的所有记录(新增记录的具体数据自定); (2)从表中删除id=1的记录,并显示删除后的所有记录; (3)修改表中记录:查询条件id=2,将name修改为:王杰,修改完毕显示所有记录; (4)查询表中id=3的记录并显示。

时间: 2024-03-31 21:37:17 浏览: 16
很抱歉,我作为一个语言模型AI,无法提供图形用户界面和数据库操作的完整程序代码。但是我可以提供一些思路和代码示例供参考。 首先,我们需要在数据库管理系统中创建一个名为"stu"的数据库,并创建一个名为"student"的表,该表有四个字段:id、Name、Sex、Age。 ```sql CREATE DATABASE stu; USE stu; CREATE TABLE student ( id INT(10) NOT NULL AUTO_INCREMENT, Name CHAR(20) NOT NULL, Sex CHAR(2) NOT NULL, Age INT(3) NOT NULL, PRIMARY KEY (id) ); INSERT INTO student (Name, Sex, Age) VALUES ('张小明', '男', 18), ('李雷', '男', 19), ('韩梅梅', '女', 18); ``` 接下来,我们可以设计一个类来封装对数据库的操作,例如: ```java import java.sql.*; public class StudentDatabase { private Connection conn; private PreparedStatement pstmt; private ResultSet rs; public StudentDatabase() { try { Class.forName("com.mysql.jdbc.Driver"); String url = "jdbc:mysql://localhost:3306/stu"; String username = "root"; String password = "password"; conn = DriverManager.getConnection(url, username, password); } catch (ClassNotFoundException | SQLException e) { e.printStackTrace(); } } public void addStudent(String name, String sex, int age) { try { pstmt = conn.prepareStatement("INSERT INTO student (Name, Sex, Age) VALUES (?, ?, ?)"); pstmt.setString(1, name); pstmt.setString(2, sex); pstmt.setInt(3, age); pstmt.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } } public void deleteStudent(int id) { try { pstmt = conn.prepareStatement("DELETE FROM student WHERE id = ?"); pstmt.setInt(1, id); pstmt.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } } public void updateStudent(int id, String name) { try { pstmt = conn.prepareStatement("UPDATE student SET Name = ? WHERE id = ?"); pstmt.setString(1, name); pstmt.setInt(2, id); pstmt.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } } public void searchStudent(int id) { try { pstmt = conn.prepareStatement("SELECT * FROM student WHERE id = ?"); pstmt.setInt(1, id); rs = pstmt.executeQuery(); while (rs.next()) { int studentId = rs.getInt("id"); String name = rs.getString("Name"); String sex = rs.getString("Sex"); int age = rs.getInt("Age"); System.out.println("id: " + studentId + ", Name: " + name + ", Sex: " + sex + ", Age: " + age); } } catch (SQLException e) { e.printStackTrace(); } } public void displayAllStudents() { try { pstmt = conn.prepareStatement("SELECT * FROM student"); rs = pstmt.executeQuery(); while (rs.next()) { int id = rs.getInt("id"); String name = rs.getString("Name"); String sex = rs.getString("Sex"); int age = rs.getInt("Age"); System.out.println("id: " + id + ", Name: " + name + ", Sex: " + sex + ", Age: " + age); } } catch (SQLException e) { e.printStackTrace(); } } public void close() { try { if (rs != null) rs.close(); if (pstmt != null) pstmt.close(); if (conn != null) conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } ``` 在上述代码中,我们使用了JDBC驱动程序连接MySQL数据库,并封装了新增、删除、更新、查询和显示学生记录等操作。 接下来,我们可以在图形用户界面中使用这些操作,例如: ```java import javax.swing.*; import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; public class StudentManagementGUI extends JFrame implements ActionListener { private JLabel nameLabel, sexLabel, ageLabel, idLabel; private JTextField nameField, sexField, ageField, idField; private JButton addButton, deleteButton, updateButton, searchButton, displayButton; private JTextArea displayArea; private StudentDatabase db; public StudentManagementGUI() { super("学生数据管理程序"); nameLabel = new JLabel("姓名"); nameField = new JTextField(10); sexLabel = new JLabel("性别"); sexField = new JTextField(2); ageLabel = new JLabel("年龄"); ageField = new JTextField(3); addButton = new JButton("添加"); addButton.addActionListener(this); deleteButton = new JButton("删除"); deleteButton.addActionListener(this); updateButton = new JButton("修改"); updateButton.addActionListener(this); searchButton = new JButton("查询"); searchButton.addActionListener(this); displayButton = new JButton("显示全部"); displayButton.addActionListener(this); displayArea = new JTextArea(10, 30); idLabel = new JLabel("ID"); idField = new JTextField(10); db = new StudentDatabase(); JPanel inputPanel = new JPanel(new GridLayout(4, 2)); inputPanel.add(nameLabel); inputPanel.add(nameField); inputPanel.add(sexLabel); inputPanel.add(sexField); inputPanel.add(ageLabel); inputPanel.add(ageField); inputPanel.add(new JLabel()); inputPanel.add(addButton); JPanel buttonPanel = new JPanel(new GridLayout(2, 2)); buttonPanel.add(deleteButton); buttonPanel.add(updateButton); buttonPanel.add(searchButton); buttonPanel.add(displayButton); JPanel idPanel = new JPanel(new GridLayout(1, 2)); idPanel.add(idLabel); idPanel.add(idField); JPanel displayPanel = new JPanel(new BorderLayout()); displayPanel.add(new JScrollPane(displayArea), BorderLayout.CENTER); displayPanel.add(idPanel, BorderLayout.SOUTH); JPanel mainPanel = new JPanel(new BorderLayout()); mainPanel.add(inputPanel, BorderLayout.NORTH); mainPanel.add(buttonPanel, BorderLayout.CENTER); mainPanel.add(displayPanel, BorderLayout.SOUTH); setContentPane(mainPanel); pack(); setVisible(true); setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); } public void actionPerformed(ActionEvent e) { if (e.getSource() == addButton) { String name = nameField.getText(); String sex = sexField.getText(); int age = Integer.parseInt(ageField.getText()); db.addStudent(name, sex, age); displayAllStudents(); } else if (e.getSource() == deleteButton) { int id = Integer.parseInt(idField.getText()); db.deleteStudent(id); displayAllStudents(); } else if (e.getSource() == updateButton) { int id = Integer.parseInt(idField.getText()); String name = nameField.getText(); db.updateStudent(id, name); displayAllStudents(); } else if (e.getSource() == searchButton) { int id = Integer.parseInt(idField.getText()); db.searchStudent(id); } else if (e.getSource() == displayButton) { displayAllStudents(); } } private void displayAllStudents() { displayArea.setText(""); db.displayAllStudents(); db.close(); } public static void main(String[] args) { new StudentManagementGUI(); } } ``` 上述代码中,我们使用了JFrame、JLabel、JTextField、JButton、JTextArea等Swing组件,实现了添加、删除、修改、查询和显示学生记录等操作,并通过StudentDatabase类封装了对数据库的操作。 当用户点击按钮时,程序会调用actionPerformed方法,根据不同的按钮执行相应的操作。例如,当用户点击“添加”按钮时,程序会从文本框中获取学生姓名、性别和年龄,调用addStudent方法向数据库中添加学生记录,并调用displayAllStudents方法显示所有学生记录。 当用户点击“显示全部”按钮时,程序会调用displayAllStudents方法,该方法会调用displayAllStudents方法从数据库中获取所有学生记录,并在文本区域中显示。 在程序中,我们也可以处理异常情况,例如在输入年龄时,用户输入了非数字字符,此时程序会抛出NumberFormatException异常。 总的来说,这个程序实现了对学生数据的管理,可以方便地添加、删除、修改、查询和显示学生记录。但这只是一个简单的示例程序,实际应用中需要考虑更多的情况和功能。

相关推荐

最新推荐

recommend-type

学籍管理系统 JAVA编写 数据库SQL2005 学籍管理系统

JAVA编写 数据库SQL2005 学籍管理系统 毕业论文 包含程序截图,需求分析 系统分析等 JAVA编写 数据库SQL2005 学籍管理系统 毕业论文 包含程序截图,需求分析 系统分析等毕业论文 包含程序截图,需求分析 系统分析等
recommend-type

数据库原理及应用实验四(存储过程和触发器)

创建一个名为stu_pr的存储过程,该存储过程能查询出051班学生的所有资料,包括学生的基本信息、学生的选课信息(含未选课同学的信息)。要求在创建存储过程前请判断该存储过程是否已创建,若已创建则先删除,并给出...
recommend-type

学生数据管理系统(包括插入,删除,修改等)

=8) /*当选择8的时候不再循环并退出*/ { switch(choose) {case 1:printf("Please input the student total:"); /*当choose为下面的数时执行相应的功能*/ scanf("%d",&N); for(i=0;i;i++) input(); save();break; ...
recommend-type

用sql修改基本表及其更新表中数据

修改基本表的基本语句: ALTER TABLE [ ADD[COLUMN] [ 完整性约束 ] ] [ ADD ] [ DROP [ COLUMN ] [CASCADE| RESTRICT] ] ... 向基本表student中增加phoneno列,数据类型为int型。 alter table stu
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

list根据id查询pid 然后依次获取到所有的子节点数据

可以使用递归的方式来实现根据id查询pid并获取所有子节点数据。具体实现可以参考以下代码: ``` def get_children_nodes(nodes, parent_id): children = [] for node in nodes: if node['pid'] == parent_id: node['children'] = get_children_nodes(nodes, node['id']) children.append(node) return children # 测试数
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依