JDBC实验测试
一、语言和环境
实现语言:Java。
环境要求:IDEA2023.3、JDK 17 、MySQL8.0、Navicat 16 for MySQL。
二、技术要求
该系统采用 SWING 技术配合 JDBC 使用 JAVA 编程语言完成桌面应用开发。
三、功能要求
某电商公司为了方便客服查看用户的订单信息,需开发一个用户订单管理系统。要求本系统实现以下功能:
- 启动程序后进入主界面,显示所有订单信息,效果如图 1 所示:

-
2.在订单编号文本框中输入正确订单号显示该订单信息,如图 2
-

-
3.选中某个订单后点击删除按钮,提示是否真的要删除,确定后删除该数据。如图 3:

4.删除成功后显示删除后订单信息。如图 4:

四、数据库设计
数据库名为 OrderDb,表结构如下。
表 1 订单表(tb_order)
| 列名
| 含义
| 数据类型
| 约束(描述)
|
| id
| 编号
| int
| 主键,自动增长
|
| name
| 商品名称
| varchar(20)
| 非空
|
| price
| 价格
| decimal(5,2)
| 非空
|
| orderID
| 所属订单单号
| varchar(20)
| 非空
|
| descinfo
| 描述
| varchar(100)
|
|
五、具体要求及推荐实现步骤
创建数据库和表
创建订单实体类
创建 BaseDAO 类完成数据库的连接和关闭
创建 OrderDAO 完成对订单的查询与删除功能
创建 MainFrame 类并添加相应组件,完成界面设计
在 MainFrame 中添加 JTable 完成数据展示。
在 MainFrame 中添加 Jbutton 完成数据删除
在 MainFrame 中添加文本框完成单条数据搜索
六、注意事项
| 题目:物流跟踪管理系统 | ||
| 该程序的评分标准如下:(测试时间90分钟) | ||
| 10 | 数据库和表 | |
|
| 正确创建数据库和表 6 分,测试数据 4 分。必须以分离数据库或脚本方式提交, 否则该项不得分 | |
| 5 | 正确创建和编写实体类,包含所有属性及方法 | |
| 10 | 正确创建并编写 BaseDAO 完成数据库的连接(5 分)和关闭(5 分)。 | |
| 30 | 正确创建并编写 OrderDAO 完成数据查询与删除 | |
|
| 10 | 列表数据查询 |
|
| 10 | 单条数据查询 |
|
| 10 | 数据删除 |
| 40 | 创建并编写 MainFrame 类完成界面设计及功能调用 | |
|
| 5 | 图 1 中各个组件的设计 |
|
| 10 | 图 1 中数据展示 |
|
| 10 | 图 2 中单条数据并正确展示在 JTable 中 |
|
| 5 | 图 3 中单条数据删除询问 |
|
| 10 | 图 4 中数据删除并展示新数据在 Jtable 中。 |
| 5 | 总体编程技术 | |
|
| 2 | 编码规范 |
|
| 3 | 注释完善 |
| 总分 | 100 分 | |
七、参考答案
(一)新建数据库orderdb,表tb_order,并插入实验数据
-- ------------------------------ Table structure for tb_order-- ----------------------------DROP TABLE IF EXISTS `tb_order`;CREATE TABLE `tb_order` (`id` int(11) NOT NULL AUTO_INCREMENT,`name` varchar(20) NOT NULL,`price` decimal(10,2) NOT NULL,`orderid` varchar(20) DEFAULT NULL,`descinfo` varchar(100) DEFAULT NULL,PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8; -- ------------------------------ Records of tb_order-- ----------------------------INSERT INTO `tb_order` VALUES ('1', 'iphones Max', '8999.00', '5325781', '刘公保的订单');INSERT INTO `tb_order` VALUES ('2', '小米10', '3655.00', '20240405', '梁思琪的订单');INSERT INTO `tb_order` VALUES ('3', '华为荣耀10', '3200.00', '20241102', '曾炳粮的订单');
(二)Java Swing
①新建com.hnjt.Bean.tb_order.java,具体代码如下。
package com.hnjt.Bean;public class tb_order {private int id;private String name;private double price;private int orderID;private String descinfo;public tb_order() {super();}public tb_order(int id, String name, double price, int orderID, String descinfo) {super();this.id = id;this.name = name;this.price = price;this.orderID = orderID;this.descinfo = descinfo;}public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public double getPrice() {return price;}public void setPrice(double price) {this.price = price;}public int getOrderID() {return orderID;}public void setOrderID(int orderID) {this.orderID = orderID;}public String getDescinfo() {return descinfo;}public void setDescinfo(String descinfo) {this.descinfo = descinfo;}}
②新建com.hnjt.BaseDAO.DbConnection.java,具体代码如下。
package com.hnjt.BaseDAO;
import java.sql.*;
import javax.swing.JOptionPane;public class DbConnection {//驱动类的类名private static final String DRIVERNAME="com.mysql.cj.jdbc.Driver";//连接数据的URL路径private static final String URL="jdbc:mysql://localhost:3306/orderdb?serverTimezone=GMT";//数据库登录账号private static final String USER="root";//数据库登录密码private static final String PASSWORD="123456";//加载驱动static{try {Class.forName(DRIVERNAME);} catch (ClassNotFoundException e) {e.printStackTrace();}}//获取数据库连接public static Connection getConnection() {try {return DriverManager.getConnection(URL,USER,PASSWORD);} catch (SQLException e) {e.printStackTrace();}return null;}//查询public static ResultSet query(String sql) {System.out.println(sql);//获取连接Connection connection=getConnection();PreparedStatement psd;try {psd = connection.prepareStatement(sql);return psd.executeQuery();} catch (SQLException e) {JOptionPane.showMessageDialog(null,"执行语句出错\n"+e.toString());e.printStackTrace();}return null;}//增、删、改、查public static int updataInfo(String sql) {System.out.println(sql);//获取连接Connection connection=getConnection();try {PreparedStatement psd=connection.prepareStatement(sql);return psd.executeUpdate();} catch (SQLException e) {JOptionPane.showMessageDialog(null,"执行语句出错\n"+e.toString());e.printStackTrace();}return 0;}//关闭连接public static void colse(ResultSet rs, Statement stmt, Connection conn) throws Exception{try {if (rs != null){rs.close();}if (stmt != null){stmt.cancel();}if (conn != null) { conn.close(); }} catch (Exception e) {e.printStackTrace(); throw new Exception();}}
}
③新建com.hnjt.OrderDAO.Update.java,具体代码如下。
package com.hnjt.OrderDAO;import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import com.hnjt.Bean.tb_order;
import com.hnjt.BaseDAO.DbConnection;
public class Update {//查询主页信息public Object[][] getMainInfo(String id) {String sql;if (id.equals("")) {sql = "select * from tb_order";}else {sql = "select * from tb_order WHERE orderid LIKE '"+id+"%';";}ResultSet re = DbConnection.query(sql);ArrayList<tb_order> list = new ArrayList<tb_order>();try {while (re.next()) {tb_order tb = new tb_order();tb.setId(re.getInt(1));tb.setName(re.getString(2));tb.setPrice(re.getDouble(3));tb.setOrderID(re.getInt(4));tb.setDescinfo(re.getString(5));list.add(tb);}} catch (SQLException e) {e.printStackTrace();}Object[][] ob = new Object[list.size()][5];for (int i = 0; i < list.size(); i++) {ob[i][0] = list.get(i).getId();ob[i][1] = list.get(i).getName();ob[i][2] = list.get(i).getPrice();ob[i][3] = list.get(i).getOrderID();ob[i][4] = list.get(i).getDescinfo();}return ob;}//删除数据public int addData(int id) {String sql = "DELETE FROM tb_order WHERE id='"+id+"';";return DbConnection.updataInfo(sql);}}
④新建com.hnjt.Vive.MainFrame.java,具体代码如下。
package com.hnjt.Vive;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JScrollPane;
import javax.swing.JTable;import java.awt.Font;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.JTextField;
import javax.swing.table.DefaultTableModel;
import com.hnjt.OrderDAO.Update;
import javax.swing.JButton;
public class MainFrame extends JFrame {private JTextField orderid;Update update = new Update();Object[] header = {"编号","商品名称","商品价格","订单编号","订单描述"};Object[][] data = update.getMainInfo("");DefaultTableModel df = new DefaultTableModel(data, header);public MainFrame() {super("物流跟踪管理系统");this.setBounds(0, 0, 700, 500);getContentPane().setLayout(null);this.setLocationRelativeTo(null);this.setResizable(false);this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);JLabel title = new JLabel("物流跟踪管理系统");title.setFont(new Font("宋体", Font.BOLD, 40));title.setBounds(182, 13, 336, 50);getContentPane().add(title);JLabel orderid_text = new JLabel("订单编号");orderid_text.setBounds(14, 70, 72, 18);getContentPane().add(orderid_text);orderid = new JTextField();orderid.setBounds(80, 67, 179, 24);getContentPane().add(orderid);orderid.setColumns(10);JButton seach = new JButton("搜索");seach.setBounds(273, 66, 90, 27);getContentPane().add(seach);seach.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent e) {if (orderid.equals("")) {JOptionPane.showMessageDialog(null, "请输入要查询的订单编号!");} else {String id = orderid.getText();data = update.getMainInfo(id);df.setDataVector(data, header);}}});JTable jTable = new JTable(df);JScrollPane scrollPane = new JScrollPane(jTable);scrollPane.setBounds(14, 104, 666, 302);getContentPane().add(scrollPane);JButton delete = new JButton("删除");delete.setBounds(590, 425, 90, 27);getContentPane().add(delete);delete.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent e) {if (jTable.getSelectedColumn()<0) {JOptionPane.showMessageDialog(null, "请选择要删除的数据!");} else {int num = JOptionPane.showConfirmDialog(null, "您真的真的要删除吗?","温馨提示", 0,1);int id = Integer.parseInt(jTable.getValueAt(jTable.getSelectedRow(), 0).toString());if(num == JOptionPane.OK_OPTION){int result = update.addData(id);if (result>0) {JOptionPane.showMessageDialog(null, "删除成功!");orderid.setText("");} else {JOptionPane.showMessageDialog(null, "删除失败!");}}}}});}
⑤新建com.hnjt.Test.Test.java,测试运行,具体代码如下。
package com.hnjt.Test;
import com.hnjt.Vive.MainFrame;
public class Test {public static void main(String[] args) {new MainFrame().setVisible(true);}
}
相关文章:
JDBC实验测试
一、语言和环境 实现语言:Java。 环境要求:IDEA2023.3、JDK 17 、MySQL8.0、Navicat 16 for MySQL。 二、技术要求 该系统采用 SWING 技术配合 JDBC 使用 JAVA 编程语言完成桌面应用开发。 三、功能要求 某电商公司为了方便客服查看用户的订单信…...
ChatGPT 摘要,以 ESS 作为你的私有数据存储
作者:来自 Elastic Ryan_Earle 本教程介绍如何设置 Elasticsearch 网络爬虫,将网站索引到 Elasticsearch 中,然后利用 ChatGPT 使用我们的私人数据来总结对其提出的问题。 Python 脚本的 Github Repo:https://github.com/Gunner…...
每日一题洛谷P2669 [NOIP2015 普及组] 金币c++
#include<iostream> using namespace std; int main() {int k;cin >> k;int sum 0;int n 1;while (k > 0) {sum n * n;k - n;n;}sum k * (n - 1);cout << sum << endl;return 0; }...
【C语言系列】深入理解指针(2)
一、数组名的理解 上一篇文章中我们写过一个这样的代码: int arr[10] {1,2,3,4,5,6,7,8,9,10}; int *p &arr[0];这里使用&arr[0] 的方式拿到了数组第⼀个元素的地址,但是其实数组名本来就是地址,而且是数组首元素的地址ÿ…...
与 Spring Boot 的无缝集成:ShardingSphere 快速集成实践
ShardingSphere 是一个轻量级的开源分布式数据库中间件,它支持分库分表、分布式事务、读写分离等功能。它能够与各种应用框架进行集成,其中与 Spring Boot 的集成非常流行,因为它能够帮助开发者在 Spring Boot 项目中快速实现高性能的分布式数…...
【QT】窗口/界面置于最前端显示,且激活该窗口
目录 0.环境 1.问题描述 2.具体实现 0.环境 windows11 qt 1.问题描述 我有一个窗口QMainWindow(也适用于QWidget或QDialog),想让其在显示的时候置于最前面,且激活成为当前活动窗口 2.具体实现 mainWindow->show();mainWind…...
DOL-288 多功能电子计时器说明书
新买一个计时器,它的用法不太直观,所以把说明书留在这里,以便以后查询。 DOL-288 多功能电子计时器说明书 1.功能说明: 正计时功能,计时上限为23小时59分59秒倒计时功能,计时上限为23小时59分59秒&#…...
14 常用的负载均衡算法
基于nginx的代理 1. 轮询算法 例如我们在nginx服务器中代理了3台服务器,再每次客户端发起请求的时候按照顺序请求挨次的发送到代理的三台服务器上。该算法比较适合每台服务器性能差不多的场景,如果部分服务器性能比较差,可能会造成性能好的…...
方法建议ChatGPT提示词分享
方法建议 ChatGPT能够根据您的具体需求提供针对性的建议,帮助您选择最合适的研究方法。通过清晰的提示,ChatGPT可以精准地为您提供最契合的研究方案。此外,它还能协助您将这些方法灵活地应用于新的研究环境,提出创新的技术解决方案…...
如何提高自动化测试覆盖率和效率
用ChatGPT做软件测试 在现代软件开发中,自动化测试已经成为保证软件质量的重要手段。然而,在实践中,自动化测试的覆盖率和效率常常受到限制,导致潜在缺陷未能及时发现或测试资源浪费。因此,提升自动化测试的覆盖率和效…...
Django学习笔记(安装和环境配置)-01
Django学习笔记(安装和环境配置)-01 一、创建python环境 1、可以通过安装Anaconda来创建一个python环境 # 创建一个虚拟python环境 conda create -n django python3.8 # 切换激活到创建的环境中 activate django2、安装django # 进入虚拟环境中安装django框架 pip install …...
【PHP】部署和发布PHP网站到IIS服务器
欢迎来到《小5讲堂》 这是《PHP》系列文章,每篇文章将以博主理解的角度展开讲解。 温馨提示:博主能力有限,理解水平有限,若有不对之处望指正! 目录 前言安装PHP 稳定版本线程安全版解压使用 PHP配置 配置文件扩展文件…...
渗透测试之SSRF漏洞原理 危害 产生的原因 探测手法 防御手法 绕过手法 限制的手段
目录 SSRF说明: SSRF攻击流程 原理: 危害: SSRF产生的原因 ssrf漏洞利用{危害} 探测手法是否存在SSRF漏洞 如何找ssrf漏洞位置 分享连接地址 google hack url关键字 PHP语言中可能出现的ssrf漏洞函数 file_get_contents sockopen() curl_exec() SSRF…...
微信小程序-base64加解密
思路:先创建一个base64.js的文件,这个文件可以作为专门加解密的文件模块,需要时就引用;创建好后,引用base64.js里的加解密函数。 注意:引用模块一定要引用正确的路径,否则会报错。 base64.js:…...
Linux shell 批量验证端口连通性
脚本 #!/bin/bash # #database check #set -o nounset LOCALIPifconfig | grep inet | head -1 | awk {print $2} | sed s/addr\:// IPLIST192.168.1.99 192.168.1.98 192.168.1.97 PORTLIST81 82 83 84 85 86 check_nc(){ for CHECK_IP in $IPLIST dofor CHECK_PORT in $PORT…...
2025-1-21 Newstar CTF web week1 wp
文章目录 week1headach3会赢吗智械危机 week1 headach3 根据提示,在页面的请求头里找到flag flag{You_Ar3_R3Ally_A_9ooD_d0ctor} 会赢吗 打开控制台,拿到第一部分flag 将地址栏改为提示,去到下一关 控制台调用函数,得到flag …...
【系统架构】如何设计一个秒杀系统?
目录 1. 什么是秒杀? 2. 秒杀系统的特点 3. 如何设计秒杀系统? 3.1 前端秒杀设计 3.2 后端秒杀设计 4. 如何保证不超卖? 4.1 库存扣减方式 4.2 服务端库存处理 5. 总结 * 知识扩展:什么是CDN? 1. 什么是秒杀…...
C++模拟实现queue
C模拟实现queue 1.queue的基本概念2.queue的基本框架3.size()成员函数4.empty()成员函数5.push()成员函数6.pop()成员函数7.front()成员函数8.back()成员函数9.完整代码 🌟🌟hello,各位读者大大们你们好呀🌟🌟 &#x…...
【2025小年源码免费送】
💖学习知识需费心, 📕整理归纳更费神。 🎉源码免费人人喜, 🔥码农福利等你领! 💖山高路远坑又深, 📕大军纵横任驰奔, 🎉谁敢横刀立马行…...
PyQt5 超详细入门级教程上篇
PyQt5 超详细入门级教程 上篇:1-3部分:PyQt5基础与常用控件 第1部分:初识 PyQt5 和安装 1.1 什么是 PyQt5? PyQt5 是 Python 的图形用户界面 (GUI) 框架,它基于强大的 Qt 库。Qt 是一个跨平台的 C 框架,用…...
qobuz-dl:无损音乐下载的技术革命与实践指南
qobuz-dl:无损音乐下载的技术革命与实践指南 【免费下载链接】qobuz-dl A complete Lossless and Hi-Res music downloader for Qobuz 项目地址: https://gitcode.com/gh_mirrors/qo/qobuz-dl 在数字音乐时代,音乐爱好者面临着一个永恒的矛盾&…...
Qwen3.5-9B中微子:探测器结构理解+相互作用模拟+数据分析提示
Qwen3.5-9B中微子:探测器结构理解相互作用模拟数据分析提示 1. 项目概述 Qwen3.5-9B是一款拥有90亿参数的开源大语言模型,具备强大的逻辑推理、代码生成和多轮对话能力。该模型支持多模态理解(图文输入)和长上下文处理ÿ…...
在物联网应用中使用 MQTT 而不是 HTTP?
然后还实际用 MQTT 实战了一下,大家感兴趣可以看看,下边是原内容: 前两年有幸参与到一个智能家居项目的开发,由于之前都没有过这方面的开发经验,所以对智能硬件的开发模式和技术栈都颇为好奇。 产品是一款可燃气体报警…...
Python爬虫入门:10步快速掌握网页数据抓取,【大数据实战】如何从0到1构建用户画像系统(案例+数据仓库+Airflow调度)。
准备工作 安装Python环境,确保版本在3.6以上。推荐使用Anaconda管理Python环境,避免版本冲突。安装必要的库,如requests、BeautifulSoup、lxml等。可以通过pip命令快速安装: pip install requests beautifulsoup4 lxml理解基本概念…...
YOLOv9官方镜像实战入门:小白也能快速上手的目标检测教程
YOLOv9官方镜像实战入门:小白也能快速上手的目标检测教程 1. 为什么选择YOLOv9官方镜像? 目标检测是计算机视觉中最实用的技术之一,但环境配置往往让初学者望而却步。YOLOv9官方镜像解决了这个痛点,它预装了所有必要的依赖项&am…...
WPF开源Office控件库全解析,利用css的动画效果制作轮播图。
WPF 开源 Office 风格控件库的技术解析 开源 Office 风格控件库的核心特性 Office 风格用户界面控件库为 WPF 开发者提供了一套高度可定制的 UI 组件,模仿 Microsoft Office(如 Ribbon、Fluent Design)的现代化设计。这类库通常包含以下核心组…...
DirectDraw兼容性新纪元:让经典游戏在现代Windows系统重生
DirectDraw兼容性新纪元:让经典游戏在现代Windows系统重生 【免费下载链接】DDrawCompat DirectDraw and Direct3D 1-7 compatibility, performance and visual enhancements for Windows Vista, 7, 8, 10 and 11 项目地址: https://gitcode.com/gh_mirrors/dd/DD…...
别再只盯着report_timing了!DC综合后,用report_constraint -all_violation全面排查时序与DRC违规(附实战解读)
别再只盯着report_timing了!DC综合后全面排查时序与DRC违规的实战指南 在数字IC设计流程中,Design Compiler(DC)综合后的时序分析环节往往让工程师们又爱又恨。面对密密麻麻的违规报告,新手工程师常陷入两个极端&#…...
基于粒子群算法的冷-热-电-气综合能源系统优化调度模型-100%详细注释+多种对比方案 摘要
基于粒子群算法的冷-热-电-气综合能源系统优化调度模型-100%详细注释多种对比方案 摘要:构建了含冷-热-电-气四种形式能源的综合能源系统优化调度模型,主要设备包括燃气锅炉、电锅炉、P2G、储能设备、风光机组、大电网、吸收式制冷机等,同时设…...
华为1+X《网络系统建设与运维(中级)》认证实验全流程解析与实战技巧
1. 华为1X认证实验环境搭建指南 第一次接触华为1X认证实验环境时,我也被那些专业术语和复杂配置搞得一头雾水。后来才发现,只要掌握几个关键点,环境搭建其实很简单。考试使用的是华为eNSP模拟器,这个软件完美复现了真实设备的功能…...
