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 框架,用…...
idea大量爆红问题解决
问题描述 在学习和工作中,idea是程序员不可缺少的一个工具,但是突然在有些时候就会出现大量爆红的问题,发现无法跳转,无论是关机重启或者是替换root都无法解决 就是如上所展示的问题,但是程序依然可以启动。 问题解决…...
Ubuntu系统下交叉编译openssl
一、参考资料 OpenSSL&&libcurl库的交叉编译 - hesetone - 博客园 二、准备工作 1. 编译环境 宿主机:Ubuntu 20.04.6 LTSHost:ARM32位交叉编译器:arm-linux-gnueabihf-gcc-11.1.0 2. 设置交叉编译工具链 在交叉编译之前&#x…...
Lombok 的 @Data 注解失效,未生成 getter/setter 方法引发的HTTP 406 错误
HTTP 状态码 406 (Not Acceptable) 和 500 (Internal Server Error) 是两类完全不同的错误,它们的含义、原因和解决方法都有显著区别。以下是详细对比: 1. HTTP 406 (Not Acceptable) 含义: 客户端请求的内容类型与服务器支持的内容类型不匹…...
MongoDB学习和应用(高效的非关系型数据库)
一丶 MongoDB简介 对于社交类软件的功能,我们需要对它的功能特点进行分析: 数据量会随着用户数增大而增大读多写少价值较低非好友看不到其动态信息地理位置的查询… 针对以上特点进行分析各大存储工具: mysql:关系型数据库&am…...
理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端
🌟 什么是 MCP? 模型控制协议 (MCP) 是一种创新的协议,旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议,它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...
Go 语言接口详解
Go 语言接口详解 核心概念 接口定义 在 Go 语言中,接口是一种抽象类型,它定义了一组方法的集合: // 定义接口 type Shape interface {Area() float64Perimeter() float64 } 接口实现 Go 接口的实现是隐式的: // 矩形结构体…...
(二)原型模式
原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…...
【android bluetooth 框架分析 04】【bt-framework 层详解 1】【BluetoothProperties介绍】
1. BluetoothProperties介绍 libsysprop/srcs/android/sysprop/BluetoothProperties.sysprop BluetoothProperties.sysprop 是 Android AOSP 中的一种 系统属性定义文件(System Property Definition File),用于声明和管理 Bluetooth 模块相…...
WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)
一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解,适合用作学习或写简历项目背景说明。 🧠 一、概念简介:Solidity 合约开发 Solidity 是一种专门为 以太坊(Ethereum)平台编写智能合约的高级编…...
AI编程--插件对比分析:CodeRider、GitHub Copilot及其他
AI编程插件对比分析:CodeRider、GitHub Copilot及其他 随着人工智能技术的快速发展,AI编程插件已成为提升开发者生产力的重要工具。CodeRider和GitHub Copilot作为市场上的领先者,分别以其独特的特性和生态系统吸引了大量开发者。本文将从功…...
