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

news2024/11/16 1:40:37

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

01、项目分析

改进实战项目——应用数据库和GUI开发产品销售管理软件(1)的设计和操作,并增加新的功能;利用按钮和文本框实现对数据库编程的主要操作,如数据表创建、记录添加、记录选择、记录更新、记录删除、数据表删除等功能。图1显示了这个实例运行后的典型显示窗口。

▍图1 实例运行后的典型运行窗口

02、类的设计

JDBCQueryFrame——用来进行JDBC数据库连接、建立包括创建、加入、选择、更新、删除、消除等SQL指令的提示以及异常处理等操作。并且创建ButtonPanel对象处理对GUI组件的布局管理和显示。

ButtonPanel——包括按钮、文本框等GUI组件的创建、事件处理、输入指令信息和输出结果显示格式处理、SQL指令的发送、回传以及显示处理以及异常处理等功能。

JDBCQueryFrameApp——测试程序,用来运行这个实战项目代码。完整源程序代码见本文压缩附件中名为JDBCQueryFrame.java以及JDBCQueryFrameApp.java。

当程序运行时,用户按下任何一个对数据表和记录操作的按钮,相应的SQL指令语法格式将显示在文本框中,提示用户的操作。例如,按下选择Select记录按钮后,将显示如图2所示窗口:

▍图2 进行选择记录操作的窗口

这时用户可以在提示处输入具体的字段列表、数据表名以及选择条件。例如,全选数据表Products所有记录的SQL指令为:

SELECT * FROM Products

按下以上指令,按下发送Submit键后,将在文本框中显示SQL指令执行结果,如图3所示。如果用户输入错误的SQL指令,将显示出错信息。

▍图3 执行SQL选择记录指令后的一个典型运行结果

以上操作包括其他对数据表记录操作的主要代码如下:


public void actionPerformed(ActionEvent e) { //事件处理
      Object source = e.getSource();
      if (source == createButton) { //建立新表事件
      setUpdateComponents();
        submitButton.setVisible(true);
        update = true;
      area.setText(createQuery);
      }
      else if(source == insertButton) { //添加记录事件
      setUpdateComponents();
        submitButton.setVisible(true);
        update = true;
      area.setText(insertQuery);
      }
    else if(source == selectButton) { //选择记录事件
        setUpdateComponents(); //调用自定义方法设置GUI显示
        submitButton.setVisible(true); //显示发送按钮
        update = false; //更新状态为假
        area.setText(selectQuery); //显示SQL选择指令语法格式
      }
      else if(source == updateButton) {
      setUpdateComponents();
        update = true;
      area.setText(updateQuery);
      }
      else if(source == deleteButton) {
      setUpdateComponents();
        update = true;
      area.setText(deleteQuery);
      }
       else if(source == dropButton) {
      setUpdateComponents();
        update = true;
      area.setText(dropQuery);
      }
     else if( source == submitButton) { //发送事件处理
        query = area.getText(); //得到SQL指令
        executeQuery(); //执行SQL指令
        resetComponents(); //重设GUI显示
        area.setText(""); //清除SQL指令
        if (update) //如果是更新操作
        JOptionPane.showMessageDialog(null, "The following SQL statement has been executed:\n" + query);
        else { //如果是选择记录操作
          displayRecords(); //调用自定义方法显示选择的记录
        }
      }
       else if(source == exitButton) {
         System.exit(0);
       }
    }

 可以看到,按下selectButton将触发对记录的选择事件处理。首先调用自定义方法setUpdateComponents(),改变GUI窗口的显示内容,并设置显示发送按钮。由于选择记录的操作与其他操作不同,需要调用Statement的executeQuery()方法,所以设置表示不同操作状态的布尔变量update为假;而利用executeUpdate()对记录和数据进行更新操作时,则设置update为真。最后调用JTextArea的方法setText()将标准记录选择指令格式显示在文本框中。按下submitButton,将触发对发送事件的处理,通过调用JTextArea的getText()获取文本框中用户修改后的选择记录指令,再调用自定义方法executeQuery()执行这个指令。这时,窗口将被重设为原先的显示状态,并且清除文本框中的内容。如果update状态为真,说明不是选择记录的操作,而是更新纪录,否则调用自定义方法displayRecords(),将这个指令执行后得到的数据表记录显示到文本框中。另外一个自定义方法makeEvenSpace()对除过每个记录的最后一列的长度进行计算,然后补加空格,使记录的每列都有相同的显示长度,便于确定记录位置和编程。如下是executeQuery()、displayRecords()以及makeEvenSpace()方法的代码:


private void executeQuery() { //自定义方法执行SQL指令
  try {
    if (update) //更新记录操作
      stmt.executeUpdate(query);
    else
      rs = stmt.executeQuery(query); //选择记录操作
  }
  catch (SQLException e) {
    JOptionPane.showMessageDialog(null, "Error in SQL statement...”);
  }
}
private void displayRecords() { //自定义方法显示执行结果
  String record = "", newRecord = ""; //初始化
  try {
    ResultSetMetaData metadata = rs.getMetaData(); //创建元数据对象
    int col = metadata.getColumnCount(); //得到记录行数
    while (rs.next()) { //循环得到所有选择的纪录
      for(int i=1; i <= col; i++) {
          colSize = metadata.getColumnDisplaySize(i);
          record = rs.getString(i); //得到记录
          if (i <= col-1) //不是最后一列
            record = makeEvenSpace(record, colSize); //补加空格
          newRecord += record + "\t";
        }
area.append(newRecord + "\n");
        record = "";
        newRecord = ""; //清除内容,为下一行准备
    }
    rs.close();
  }
  catch (SQLException sqle) {
       JOptionPane.showMessageDialog(null, "Error in SQL statement...");
  }
  catch (NullPointerException e) {
    JOptionPane.showMessageDialog(null, "No such record found...");
  }
}

 关于设置和更新GUI窗口显示的代码,以及对记录和数据表的其他操作与选择记录有所相似!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/138338.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

荣耀破壁2022:蜕变的解法、蓄势的护法、进击的打法

“世上只有一种英雄主义&#xff0c;那就是在认清生活的真相后依然热爱生活”&#xff0c; 罗曼罗兰在《米开朗琪罗传》中写道。人如此&#xff0c;企业亦如此。12月30日&#xff0c;荣耀在新年致辞中提到&#xff1a;“真正的勇敢是在认清真相后依然热爱。”刚过去的2022年&am…

zOffice新年新版本!多项实用功能上线

2022年发生了很多大事&#xff0c;你们在2022年做过最有意义的事情是什么呢&#xff1f;或许这一年我们有很多不足&#xff0c;或许我们依旧还需努力&#xff0c;但是我们都将继续寻找人生的新篇章&#xff0c;在2023年到来之际&#xff0c;联想Filez也祝大家新年快乐&#xff…

都2023年了,诸佬们肯定熟知RabbitMQ了吧

前言&#xff1a;大家好&#xff0c;我是小威&#xff0c;24届毕业生&#xff0c;曾经在某央企公司实习&#xff0c;目前入职某税务公司。本篇文章将记录和分享RabbitMQ相关的知识点。 本篇文章记录的基础知识&#xff0c;适合在学Java的小白&#xff0c;也适合复习中&#xff…

EXCEL的查找:如何按 行号+列号 进行查询, 可用indirect() + match() 或 index() + match()

0 首先用match()等取得行号&#xff0c;列号 如果想根据行号列号&#xff0c;精确查找&#xff0c;另外一个区域的数据&#xff0c;可以用如下方法 INDIRECT("Sheet2!r"&MATCH($C11,Sheet2!$A:$A,0)&"C"&MATCH(D$10,Sheet2!$1:$1,0),FALSE) …

ERR_UNSAFE_PORT浏览器安全问题导致无法访问的解决方案

前言 出发点是Java Agent内存马的自动分析与查杀&#xff0c;实际上其他内存马都可以通过这种方式查杀 本文主要的难点主要是以下三个&#xff0c;我会在文中逐个解答 1.如何dump出JVM中真正的当前的字节码 2.如何解决由于LAMBDA表达式导致非法字节码无法分析的问题 3.如何对…

短视频带货流程话术

现在短视频热度高涨&#xff0c;已经成为人们娱乐休闲的一种方式。短视频人流量大&#xff0c;已经衍生出了直播带货、橱窗链接带货等方式&#xff0c;也吸引了一批想要带货的用户。前言现在短视频热度高涨&#xff0c;已经成为人们娱乐休闲的一种方式。短视频人流量大&#xf…

JDBC(使用java语言操作数据库)

JDBC概念&#xff1a;使用Java语言操作关系型数据库的一套api&#xff08;可以用一套标准的jdbc操作所有类型的数据库&#xff0c;jdbc是接口&#xff0c;每一个数据库&#xff08;mysql、oracle、db2...&#xff09;都去实现jdbc的接口&#xff0c;每个数据库的实现类都不一样…

LeetCode:11. 盛最多水的容器

11. 盛最多水的容器1&#xff09;题目2&#xff09;思路3&#xff09;代码4&#xff09;结果1&#xff09;题目 给定一个长度为 n 的整数数组 height 。有 n 条垂线&#xff0c;第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。 找出其中的两条线&#xff0c;使得它们与 x …

2023年1月4日:fastadminApi接口开发项目时遇到的问题

SelectPage selectpage(官方文档&#xff1a;动态下拉(SelectPage) - FastAdmin框架文档 - FastAdmin开发文档) 常规用法 下面介绍一个基础的动态下拉列表示例&#xff0c;如下 <input id"c-name" data-rule"required" data-source"category/sel…

AVS3变换之IST和ISTS

IST&#xff08;Implicit Selected Transform&#xff09;是AVS3中新增的针对intra块的变换工具&#xff0c;IST对intra块提供了两种可分离的变换核&#xff0c;编码器根据RDO选择最优的变换核&#xff0c;但是对于选中的变换核不在码流中传输其索引&#xff0c;而是将其索引隐…

day34【代码随想录】贪心算法之跳跃游戏、跳跃游戏||、K次取反后最大化的数组和

文章目录前言一、跳跃游戏&#xff08;力扣55&#xff09;二、跳跃游戏 II&#xff08;力扣45&#xff09;三、K次取反后最大化的数组和&#xff08;力扣1005&#xff09;前言 1、跳跃游戏 2、跳跃游戏|| 3、K次取反后最大化的数组和 一、跳跃游戏&#xff08;力扣55&#xff…

火热的低代码到底是什么?

低代码风头正紧&#xff0c;也是最近一段时间跟云原生一起被热捧&#xff0c;不管你是做后端开发、还是前端设计、销售、售前&#xff0c;如果你没接触过低代码你都不好意思说自己在软件领域工作&#xff0c;这边文章从我的角度聊聊低代码是什么、以怎么样的方式开发、及低代码…

react笔记_05函数组件与类组件的区别之capture value特性

函数组件与类组件在写法没有好坏之分&#xff0c;性能差距也几乎可以忽略&#xff0c;而且 React 会长期支持这两种写法。 React的函数式组件和类组件之间的根本区别 在心智模型上。 函数式组件具有 capture value 特性。 capture value特性 Capture Value 从字面上可以理解…

【已解决】office提示你的许可证不是正版,你可能是盗版软件的受害者?

三步即可先看效果步骤1、下载工具2、找到 修复Office许可证明问题3、填入KMS主机&#xff0c;点击修复如何查看正在使用的 KMS 主机地址&#xff1f;先看效果 步骤 1、下载工具 工具下载&#xff1a;https://otp.landian.vip/zh-cn/ 2、找到 修复Office许可证明问题 3、填入…

PEM格式RSA密钥解析(一)

Base64转16进制格式 后缀是.PEM 的数字证书是 BASE64 编码的&#xff0c;以 ASCII 码来表示。常见的证书如下所示&#xff08;以 RSA1024 为例&#xff09;&#xff1a; 私钥&#xff1a; ----BEGIN RSA PRIVATE KEY----- MIICWwIBAAKBgHU4CF6yvqb5WBhwcYfvh/o3NpwcSJlcfj0nIZ…

下载神器IDM安装与使用(保姆级教程)

下载神器IDM安装与使用&#xff08;保姆级教程&#xff09; 文章目录下载神器IDM安装与使用&#xff08;保姆级教程&#xff09;前言一、下载地址二、IDM是什么&#xff1f;三、作用与特点四、安装步骤总结前言 众所周知&#xff0c;下载工具是大家电脑里必装的软件之一。 但大…

大数据时代,制造业人要知道,为什么有ERP还要上SRM系统

每个公司都是在一个供应链中&#xff0c;每个公司都有自己的上下游。如今&#xff0c;企业间的竞争已不再是单一企业的单打独斗&#xff0c;而是由价值链与价值链、供应链与供应链的较量。上游厂商&#xff08;供应商&#xff09;直接影响到公司的产品与服务的价格及竞争能力。…

零售企业全域数据打通最佳实践

在数字化转型的实战中&#xff0c;零售企业面临着巨大的挑战&#xff0c;过去三年线下流量锐减&#xff0c;甚至不少门店关停&#xff0c;不少零售企业布局线上&#xff0c;但是这个也给零售企业带来另外一个挑战&#xff1a;IT资源有限的情况下&#xff0c;线上&线下的流量…

密码学_RC4算法

在密码学中&#xff0c;RC4&#xff08;来自Rivest Cipher 4的缩写&#xff09;是一种流加密算法&#xff0c;密钥长度可变。它加解密使用相同的密钥&#xff0c;因此也属于对称加密算法。RC4是有线等效加密&#xff08;WEP&#xff09;中采用的加密算法&#xff0c;也曾经是TL…

电脑看不了视频?视频恢复,3个方案解决

一般电脑播放不了视频&#xff0c;原因大多是Flash插件损坏了&#xff0c;因为电脑上的视频和所有的Flash都需要Flash插件才可以正常使用。电脑看不了视频怎么办&#xff1f;你需要对Flash进行修复或者重新安装它。一起来看看下面三个方案&#xff0c;解决电脑视频看不了的问题…