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

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

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

01

项目分析

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

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

02

类的设计

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

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

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

完整程序见压缩附件中名为JDBCProductFrame.java以及JDBCProductFrameApp.java的源代码。(关注微信公众号,后台回复关键词 “Java数据库编程” 即可获得完整源代码。)

如下是JDBCProductFrame的主要代码:

//创建与数据库连接的有GUI组件用来执行显示、添加、更新、删除、退出操作的窗口

classJDBCProductFrameextendsJFrame{

StringcolumnNames[] = { “Product Code”, “Product Name”, “Product Price”}; //定义产品字段名

Stringrecords[][]; //储存数据表

Stringrecord[] = newString[ 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 = newDefaultTableModel(records, columnNames); //创建数据表显示

table = newJTable(model); //创建表

scrollPane = newJScrollPane(table); //创建滑标

add(scrollPane, BorderLayout.CENTER); //注册显示表

panel = newButtonPanel; //创建按钮控制板

add(panel, BorderLayout.SOUTH); //注册显示控制板

setDefaultCloseOperation(EXIT_ON_CLOSE);

}

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

privatevoidmakeJDBCConnection { //自定义方法连接数据库

try{

Class.forName( “com.mysql.cj.jdbc.Driver”);

StringdbURL = “jdbc:mysql://localhost:3306/ProductDB”;

Stringusername = “root”;

Stringpassword = “NewJavaBook2018”;

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的代码如下:

privatevoidgetResult( ) { //自定义方法得到数据表

try{

rs = stmt.executeQuery( “SELECT * FROM Products”); //选择产品数据表中的所有记录

}

catch(SQLException e) {

JOptionPane.showMessageDialog( null, “Error in SQL statement…”);

}

}

privatevoidbuildRecordTable( ) { //自定义方法建立记录数组

try{

rs.last; //记录指示器到最后记录

rows = rs.getRow; //得到记录数

records = newString[rows][ 3]; //创建二维数组储存记录表

introw = 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组件、事件处理以及布局管理功能。主要代码如下:

//这个控制板用来实现按钮和文本字段组件的创建、布局、事件处理等与记录操作有关的功能

classButtonPanelextendsJPanelimplementsActionListener{

//内部类创建控制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; //调用自定义方法设置组件

}

publicvoidactionPerformed(ActionEvent e){ //完善事件处理功能

Object source = e.getSource;

if(source == addButton) { //如果是添加记录

setUpdateComponents; //调用自定义方法重设其他组件的显示

submitButton.setVisible( true); //显示发送按钮

sendButton.setVisible( false); //不显示提交更新按钮

}

elseif(source == updateButton) { //如果是更新记录

setUpdateComponents; //调用自定义方法重设其他组件的显示

sendButton.setVisible( true); //显示提交更新按钮

submitButton.setVisible( false); //不显示发送按钮

setUpdateRecord; //调用自定义方法设置更新的记录

model.removeRow(row); //将旧的记录从显示表中删除

}

elseif(source == sendButton) { //如果是提交更新按钮

updateRecord; //调用自定义方法更新记录

getLastRecord; //调用自定义方法得到更新后的记录

model.insertRow(row, record); //将这个记录加入显示表中原来位置

clearFields; //取出各字段的内容

resetComponents; //调用自定义方法重设组件显示

}

elseif(source == deleteButton) { //如果是删除按钮

deleteRecord; //调用自定义方法删除记录

}

elseif( source == submitButton) { //如果是添加记录的发送按钮

String code = codeField.getText; //得到记录的各字段值

String title = titleField.getText;

doubleprice = Double.parseDouble(priceField.getText);

insertRecord(code, title, price); //调用自定义方法加入记录

setLastRecord; //设置添加后的记录到数组record中

clearFields; //清除各字段的显示

model.addRow(record); //将这个记录加在显示表的尾部

}

elseif(source == returnButton) { //如果是返回按钮

clearFields; //清除各字段显示

resetComponents; //重设组件显示

}

elseif(source == exitButton) { //如果是退出按钮

System.exit( 0); //结束程序运行

}

}

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

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

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

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

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

//自定义方法设置更新的组件显示

privatevoidsetUpdateComponents{

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,把这些字段值添加到数据表中。这个方法的代码如下:

//利用预备指令将记录添加到记录表中

privatevoidinsertRecord( Stringcode, Stringtitl, double price) { //自定义方法

try{

StringinsertSql = “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

privatevoidsetLastRecord{

record[ 0] = codeField.getText; //record[0]储存产品代码

record[ 1] = titleField.getText; //record[1]储存产品名称

record[ 2] = priceField.getText; //record[2]储存产品价格

}

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

03

源代码下载

关注微信公众号,后台回复关键词 “Java数据库编程” 即可获得完整源代码。

04

参考书籍

Java高手是怎样练成的:原理、方法与实践

ISBN:978-7-302-56384-6

高永强 卢晨 编著

定价:118元

05

精彩文章回顾

  • Java高手速成│Java程序怎样和数据库对话(附代码)

  • Java高手速成│编写你第一个数据库程序(附代码)

  • 手把手教会你Java集合类泛类型

  • Java 15新增类Record的工作实例|附代码

  • 大数据时代银行如何玩转数据挖掘

  • Office实训:在Word中用索引文件自动标记关键词和制作索引|附素材+视频

  • 微信小程序实训:基于云数据库的许愿墙|附源码+视频

  • Python模拟浏览器实训:自动登陆邮箱|附视频

  • Python爬虫实训:实现图书信息采集|附源码+视频

  • Spark基本统计–基于DataFrame的API|附视频

  • Spark算法实例:词频统计

  • 大数据集群的部署实例|附视频

  • 用Excel制作工资条实例|附素材+视频

  • 真题解析│2017年蓝桥杯软件类省赛传统“送分题”

责任编辑:

Thenews.cc