Java高手速成│实战:应用数据库和GUI开发产品销售管理软件(1)
创始人
2024-05-05 05:55:27
0

实战项目:应用数据库和GUI开发产品销售管理软件

01、项目分析

应用各种数据库编程技术,并利用GUI组件,例如按钮、标签、文本字段提供增添、更新、删除产品销售记录等功能。利用JTable显示产品销售数据表中的记录。图1显示了这个实战项目的典型GUI窗口、数据表和操作功能按钮。

▍图1 实战项目典型GUI窗口、数据表和操作功能按钮

02、类的设计

ButtonPanle——创建包括添加记录(Add)、更新记录(Update)、删除记录(Delete)以及停止运行(Stop)这四个GUI组件,利用布局管理将它们显示到窗口底部。并执行事件处理以及异常处理功能。

JDBCProductFrame——创建JTable对象用来显示记录的数据表、提供与数据库连接以及发送各种SQL指令的方法,执行将回传结果显示到数据表中的各种功能。

JDBCProductFrameApp——测试程序运行这个实战程序。

如下是JDBCProductFrame的主要代码:

//创建与数据库连接的有GUI组件用来执行显示、添加、更新、删除、退出操作的窗口
class JDBCProductFrame extends JFrame {String columnNames[] = { "Product Code", "Product Name", "Product Price" };//定义产品字段名String records[][]; //储存数据表String record[] = new String[3]; //储存选择的记录int rows = 0; //总记录行初始化int row = 0; //当前记录行初始化JTable table; //声明JTableDefaultTableModel model; //声明表模式JScrollPane scrollPane; //声明滑标JPanel panel; //声明控制板Connection connection; //声明连接Statement stmt = null ; //初始化ResultSet rs = null;JDBCProductFrame() { //构造方法makeJDBCConnection(); //调用自定义方法与数据库连接getResult(); //调用自定义方法得到数据表buildRecordTable(); //调用自定义方法建立数据表model = new DefaultTableModel(records, columnNames);//创建数据表显示table = new JTable(model); //创建表scrollPane = new JScrollPane(table); //创建滑标add(scrollPane, BorderLayout.CENTER); //注册显示表panel = new ButtonPanel(); //创建按钮控制板add(panel, BorderLayout.SOUTH); //注册显示控制板setDefaultCloseO

 在JDBCProductFrame构造方法中,分别调用了3个自定义方法makeJDBCConnection()、getResult()、buildRecordTable()来完成对数据库连接、得到数据表以及设立用来储存数据表的二维数组records各元素值的任务。makeJDBCConnection()的代码如下:

private void makeJDBCConnection() { //自定义方法连接数据库try{Class.forName("com.mysql.cj.jdbc.Driver");String dbURL = "jdbc:mysql://localhost:3306/ProductDB";String username = "root";String password = "********";connection = DriverManager.getConnection(dbURL, username, password);stmt = connection.createStatement();}catch(ClassNotFoundException e){JOptionPane.showMessageDialog(null, "JDBC driver is not found.");}catch(SQLException e){JOptionPane.showMessageDialog(null,"Error: " + e.getMessage());}

 getResult()以及buildRecords()的代码如下:

private void getResult() { //自定义方法得到数据表try {rs = stmt.executeQuery("SELECT * FROM Products"); //选择产品数据表中的所有记录}catch (SQLException e) {JOptionPane.showMessageDialog(null, "Error in SQL statement...");}
}
private void buildRecordTable() { //自定义方法建立记录数组try {rs.last(); //记录指示器到最后记录rows = rs.getRow(); //得到记录数records = new String[rows][3]; //创建二维数组储存记录表int row = 0;rs.beforeFirst(); //设置记录指示器while (rs.next()) { //如果有下一个记录records[row][0] = rs.getString(1); //设置记录到数组records[row][1] = rs.getString(2);records[row][2] = "" + rs.getDouble(3);row++; //下一行记录}rs.close();}catch (SQLException e) {JOptionPane.showMessageDialog(null, " Error in SQL statement...");}
}

为了得到记录表中的总记录数,首先调用ResultSet的last()方法,将记录指示器指向最后一个记录,然后调用其getRow()得到总记录数。在提取rs中的记录之前,还必须重设记录指示器,以便在while循环中利用next()方法,控制记录的读出操作。

在内部类ButtonPanel中,创建和设置了所有GUI组件、事件处理以及布局管理功能。主要代码如下:

//这个控制板用来实现按钮和文本字段组件的创建、布局、事件处理等与记录操作有关的功能
class ButtonPanel extends JPanel implements ActionListener {
//内部类创建控制GUI组件JButton addButton, updateButton, deleteButton, submitButton, sendButton, returnButton, exitButton;JLabel codeLabel, titleLabel, priceLabel;JTextField codeField, titleField, priceField;FlowLayout flowLayout;String message = "You must select a record in the table first...";ButtonPanel() { //构造方法setupGUI(); //调用自定义方法设置组件}public void actionPerformed(ActionEvent e) { //完善事件处理功能Object source = e.getSource();if (source == addButton) { //如果是添加记录setUpdateComponents(); //调用自定义方法重设其他组件的显示submitButton.setVisible(true); //显示发送按钮sendButton.setVisible(false); //不显示提交更新按钮}else if(source == updateButton) { //如果是更新记录setUpdateComponents(); //调用自定义方法重设其他组件的显示sendButton.setVisible(true); //显示提交更新按钮submitButton.setVisible(false); //不显示发送按钮setUpdateRecord(); //调用自定义方法设置更新的记录model.removeRow(row); //将旧的记录从显示表中删除}else if(source == sendButton) { //如果是提交更新按钮updateRecord(); //调用自定义方法更新记录getLastRecord(); //调用自定义方法得到更新后的记录model.insertRow(row, record); //将这个记录加入显示表中原来位置clearFields(); //取出各字段的内容resetComponents(); //调用自定义方法重设组件显示}else if(source == deleteButton) { //如果是删除按钮deleteRecord(); //调用自定义方法删除记录}else if( source == submitButton) { //如果是添加记录的发送按钮String code = codeField.getText(); //得到记录的各字段值String title = titleField.getText();double price = Double.parseDouble(priceField.getText());insertRecord(code, title, price); //调用自定义方法加入记录setLastRecord(); //设置添加后的记录到数组record中clearFields(); //清除各字段的显示model.addRow(record); //将这个记录加在显示表的尾部}else if(source == returnButton) { //如果是返回按钮clearFields(); //清除各字段显示resetComponents(); //重设组件显示}else if(source == exitButton) { //如果是退出按钮System.exit(0); //结束程序运行}}

代码中,自定义方法setupGUI()将所有控制组件,例如按钮以及文本字段,布局以及显示到窗口的适当位置,并注册各按钮的事件处理。这里不再详细讨论其具体代码。

在事件处理代码中,由于添加记录和更新记录执行不同的操作,所以创建发送按钮submitButton来处理增加新记录的事件;而利用提交按钮sendButton处理更新记录的操作。

如果用户按下了添加记录按钮addButton,将调用自定义方法setUpdateComponents(),设置如图2的窗口显示,用来处理增添记录的操作。

▍图2 用来执行添加记录操作的窗口

setUpdateComponents()的显示协调部分代码如下:

//自定义方法设置更新的组件显示
private void setUpdateComponents() {codeLabel.setVisible(true);titleLabel.setVisible(true);priceLabel.setVisible(true);codeField.setVisible(true);titleField.setVisible(true);priceField.setVisible(true);addButton.setVisible(false);updateButton.setVisible(false);deleteButton.setVisible(false);exitButton.setVisible(false);returnButton.setVisible(true);
}

 当用户输入记录信息并按下发送按钮后,将触发submitButton事件。得到3个文本字段的内容后,调用自定义方法insertRecord(),把这些字段值添加到数据表中。这个方法的代码如下:

//利用预备指令将记录添加到记录表中
private void insertRecord(String code, String titl, double price) { //自定义方法try {String insertSql = "INSERT INTO Products (Code, Title, Price) VALUES( ?, ?, ?)";//预备指令PreparedStatement ps = connection.prepareStatement(insertSql); //执行预备指令ps.setString(1, code);ps.setString(2, title);ps.setDouble(3, price);ps.executeUpdate(); //执行SQL指令ps.close();}catch (SQLException e) {JOptionPane.showMessageDialog(null, "Error in SQL statement...");}
}

可以看到,三个问号分别被赋予产品代码、产品名称以及产品价格的值。

除此之外,还必须更新显示表中的内容,使之显示新增添的记录。这个操作通过首先调用自定义方法setLastRecord(),并且调用DefaultTableModel的方法addRow()来实现。setLastRecord()的代码如下:

//自定义方法将新记录内容设置到数组record
private void setLastRecord() {record[0] = codeField.getText(); //record[0]储存产品代码record[1] = titleField.getText(); //record[1]储存产品名称record[2] = priceField.getText(); //record[2]储存产品价格}

 最后清除文本字段,调用另外一个自定义方法resetComponents(),重设按钮的显示。具体代码与以上讨论的updateComponents()方法基本相同。你可参考这个例子,或者查阅ButtonPanel完整程序。其他对记录的操作,如更新记录、删除记录以及退出程序运行,遵循与添加记录操作相同的原则!

03、源代码下载

JDBCExamples.zip - 坚果云 - 云盘|网盘|企业网盘|同步|备份|无限空间|免费网络硬盘|企业云盘

相关内容

热门资讯

微信安卓系统转苹果系统,轻松实... 你有没有想过,从微信安卓系统转到苹果系统,这中间的转换过程,就像是一场说走就走的旅行,充满了未知和惊...
如何刷安卓8.0系统,安卓8.... 你有没有想过,让你的安卓手机升级到最新的8.0系统,让它焕发出全新的活力呢?别急,今天我就来给你详细...
安卓系统里查看路由,安卓系统下... 你是不是也和我一样,对家里的无线网络充满了好奇?想知道安卓手机里怎么查看路由器信息?那就跟着我一起探...
手机出现安卓系统信号,手机信号... 你有没有发现,最近你的安卓手机信号好像变得特别不稳定呢?是不是觉得有时候信号满格,却还是接不到电话,...
创维安卓系统怎么安装,享受智能... 你家的创维电视是不是最近有点儿不给力,想要给它来个升级,让它焕发新生呢?那就得给它装个安卓系统啦!别...
中兴刷原生安卓系统,原生安卓系... 亲爱的读者们,你是否厌倦了那些千篇一律的安卓系统,想要给你的手机来点新鲜感?今天,就让我带你一起探索...
云系统与安卓系统软件,构建智能... 你有没有想过,你的手机里那些神奇的软件,其实都是靠云系统和安卓系统软件的默契配合才变得如此强大呢?想...
如何禁止安卓系统联网,全方位操... 你有没有想过,你的安卓手机其实是个小宇宙,里面藏着无数的秘密和信息?但是,你知道吗?有时候,这些信息...
a安卓系统不兼容,揭秘a设备的... 最近是不是发现你的安卓手机有些不对劲?比如,某个APP突然罢工了,再比如,你下载了一个新游戏,结果发...
安卓系统刷固件教程,解锁设备潜... 你有没有想过,你的安卓手机其实就像一个隐藏着无限可能的宝藏呢?没错,就是那个你每天不离手的宝贝。今天...
电脑系统安卓界面,功能与美学的... 你有没有发现,现在手机和电脑的界面越来越像了呢?没错,就是那个我们每天都要打交道的好伙伴——安卓界面...
吃鸡王座安卓系统,登顶吃鸡巅峰 你有没有想过,在手机游戏中,谁才是真正的“吃鸡王座”呢?今天,就让我带你一探究竟,看看安卓系统上的那...
安卓点名系统下载,安卓点名系统... 你有没有想过,在繁忙的学习生活中,有没有一种神奇的工具,能让你轻松管理课堂纪律,还能让点名变得如此有...
手机安装通用安卓系统,引领智能... 你有没有想过,为什么你的手机可以安装那么多好玩的应用?秘密就在于它搭载了通用安卓系统!想象一个系统就...
安卓系统仿真器,功能与操作指南 你有没有想过,在电脑上也能玩安卓游戏?没错,这就是安卓系统仿真器的神奇之处!想象你坐在电脑前,手握鼠...
安卓系统可以刷街机,畅享虚拟游... 你知道吗?现在用安卓系统刷街机,简直就像变魔术一样神奇!没错,就是那种让你仿佛穿越回童年,手握游戏杆...
安卓系统画画软件画笔,绘制无限... 你有没有发现,手机里的画画软件越来越丰富啦?尤其是安卓系统上的那些,简直让人眼花缭乱。今天,就让我带...
安卓系统垃圾和缓存,提升使用体... 手机里的安卓系统是不是越来越慢了?是不是觉得打开一个应用都要等半天?别急,今天就来跟你聊聊安卓系统里...
安卓系统图片转入苹果,轻松实现... 你是不是也有过这样的烦恼?手机里存了好多珍贵的照片,突然想换手机,却发现安卓系统的照片怎么也弄不到苹...
华为matebooke装安卓系... 你有没有想过,你的华为MateBook也能装上安卓系统呢?没错,就是那个我们平时手机上用的安卓系统!...