写点什么

Java 高手速成│实战:应用数据库和 GUI 开发产品销售管理软件(1)

作者:TiAmo
  • 2023-01-03
    江苏
  • 本文字数:4306 字

    阅读完需:约 14 分钟

Java高手速成│实战:应用数据库和GUI开发产品销售管理软件(1)

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; //声明JTable   DefaultTableModel 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()的代码如下:

//自定义方法将新记录内容设置到数组recordprivate 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 - 坚果云 - 云盘|网盘|企业网盘|同步|备份|无限空间|免费网络硬盘|企业云盘


发布于: 2023-01-03阅读数: 23
用户头像

TiAmo

关注

有能力爱自己,有余力爱别人! 2022-06-16 加入

CSDN全栈领域优质创作者;阿里云创作者社区专家博主、技术博主、星级博主;华为云享专家;

评论

发布
暂无评论
Java高手速成│实战:应用数据库和GUI开发产品销售管理软件(1)_JDBC_TiAmo_InfoQ写作社区