0

0

Java中如何有效记录和管理交易历史数据

霞舞

霞舞

发布时间:2025-07-20 21:34:11

|

277人浏览过

|

来源于php中文网

原创

Java中如何有效记录和管理交易历史数据

在Java应用中,记录和管理交易历史数据是常见需求。本文将详细介绍如何利用Java的集合框架,特别是java.util.List,结合自定义对象来有效地存储和检索交易记录。我们将通过实际代码示例,展示如何定义交易数据结构、如何在交易发生时将其添加到历史记录中,以及如何方便地查询这些记录,同时探讨数据持久化等进阶概念。

核心概念:交易记录的数据结构

在处理类似银行转账的场景时,仅仅在方法执行完毕后打印结果是不够的,我们需要将每次交易的关键信息(如转账方、收款方、金额、时间等)保存下来,以便后续查询或分析。简单地使用独立变量来存储这些信息是不可行的,因为每次方法调用都会覆盖前一次的数据,且无法存储多条记录。

为了有效地管理多条交易记录,我们需要:

  1. 定义一个自定义类来表示单条交易记录。 这个类将封装一笔交易的所有相关属性,例如:

    • sender (发送方)
    • receiver (接收方)
    • amount (交易金额)
    • timestamp (交易时间) 通过将这些属性组合成一个对象,我们可以更好地组织数据,并使代码更具可读性和可维护性。
  2. 使用集合框架来存储这些交易对象。 java.util.List 是一个非常适合的接口,它代表一个有序的元素序列。ArrayList 是 List 接口的一个常用实现,它提供了动态数组的功能,可以方便地添加和访问元素。

下面是 Transaction 类的定义示例:

立即学习Java免费学习笔记(深入)”;

文心大模型
文心大模型

百度飞桨-文心大模型 ERNIE 3.0 文本理解与创作

下载
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;

/**
 * 表示一笔银行交易的记录。
 */
public class Transaction {
    private String sender;
    private String receiver;
    private double amount;
    private LocalDateTime timestamp; // 使用LocalDateTime记录交易发生的时间

    /**
     * 构造函数,用于创建新的交易记录。
     * @param sender 交易的发送方。
     * @param receiver 交易的接收方。
     * @param amount 交易的金额。
     */
    public Transaction(String sender, String receiver, double amount) {
        this.sender = sender;
        this.receiver = receiver;
        this.amount = amount;
        this.timestamp = LocalDateTime.now(); // 默认记录当前系统时间
    }

    // 为所有属性提供公共的getter方法,以便外部访问
    public String getSender() {
        return sender;
    }

    public String getReceiver() {
        return receiver;
    }

    public double getAmount() {
        return amount;
    }

    public LocalDateTime getTimestamp() {
        return timestamp;
    }

    /**
     * 重写toString方法,提供友好的交易信息字符串表示。
     * @return 格式化的交易详情字符串。
     */
    @Override
    public String toString() {
        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
        return "交易时间: " + timestamp.format(formatter) +
               ", 发送方: " + sender +
               ", 接收方: " + receiver +
               ", 金额: " + String.format("%.2f", amount) + "元";
    }
}

实现交易历史记录

有了 Transaction 类,我们就可以在每次转账成功后,创建一个 Transaction 对象,并将其添加到 List 中。这个列表通常需要作为应用程序的某个全局或可访问的成员变量来维护。

以下是一个简化的银行应用示例,演示了如何集成交易历史记录功能:

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class BankingApp {
    private static double balance = 1000.0; // 假设初始余额
    private static Scanner scanner = new Scanner(System.in);
    private static String currentUser = "我的账户"; // 假设当前用户

    // 声明一个静态的List来存储所有交易记录
    private static List transactionHistory = new ArrayList<>();

    public static void main(String[] args) {
        runApplication(); // 启动应用程序主循环
    }

    /**
     * 应用程序主循环,显示菜单并处理用户输入。
     */
    public static void runApplication() {
        int choice;
        do {
            System.out.println("\n--- 银行应用主菜单 ---");
            System.out.println("1. 转账");
            System.out.println("2. 查看交易历史");
            System.out.println("3. 查看当前余额");
            System.out.println("4. 退出");
            System.out.print("请选择操作: ");

            if (scanner.hasNextInt()) {
                choice = scanner.nextInt();
                scanner.nextLine(); // 消费掉换行符,避免影响下一次nextLine()
            } else {
                System.out.println("无效输入,请输入数字选项。");
                scanner.nextLine(); // 消费掉无效输入
                choice = 0; // 设置为无效选项,继续循环
                continue;
            }

            switch (choice) {
                case 1:
                    moneyTransfer();
                    break;
                case 2:
                    viewTransactionHistory();
                    break;
                case 3:
                    System.out.println("当前余额: " + String.format("%.2f", balance) + "元");
                    break;
                case 4:
                    System.out.println("感谢使用,再见!");
                    break; // 退出循环
                default:
                    System.out.println("无效选择,请重新输入。");
            }
        } while (choice != 4);
        scanner.close(); // 关闭Scanner资源
    }

    /**
     * 处理资金转账操作。
     */
    public static void moneyTransfer() {
        System.out.println("\n--- 转账功能 ---");
        System.out.print("请输入收款人姓名: ");
        String receiverName = scanner.nextLine();

        System.out.print("请输入转账金额: ");
        double transferAmount;
        if (scanner.hasNextDouble()) {
            transferAmount = scanner.nextDouble();
            scanner.nextLine(); // 消费换行符
        } else {
            System.out.println("无效金额,请输入数字。");
            scanner.nextLine(); // 消费无效输入
            return; // 返回主菜单
        }

        if (transferAmount <= 0) {
            System.out.println("转账金额必须大于零。");
        } else if (balance < transferAmount) {
            System.out.println("余额不足,无法完成转账。当前余额: " + String.format("%.2f", balance) + "元");
        } else {
            balance -= transferAmount;
            // 创建Transaction对象并添加到历史记录列表
            Transaction transaction = new Transaction(currentUser, receiverName, transferAmount);
            transactionHistory.add(transaction);

            System.out.println("您已成功转账 " + String.format("%.2f", transferAmount) + " 元给用户: " + receiverName);
            System.out.println("当前余额: " + String.format("%.2f", balance) + "元");
        }
    }

    /**
     * 查看所有交易历史记录。
     */
    public static void viewTransactionHistory() {
        System.out.println("\n--- 交易历史记录 ---");
        if (transactionHistory.isEmpty()) {
            System.out.println("目前没有交易记录。");
        } else {
            // 遍历并打印每一条交易记录
            for (Transaction t : transactionHistory) {
                System.out.println(t); // 调用Transaction类的toString方法进行格式化输出
            }
        }
    }
}

在上述代码中:

  • transactionHistory 是一个 List 类型的静态变量,用于在整个应用程序生命周期中存储交易记录。
  • 在 moneyTransfer 方法中,当转账成功后,我们创建一个新的 Transaction 对象,并使用 transactionHistory.add(transaction); 将其添加到列表中。
  • runApplication 方法使用一个 do-while 循环来持续显示菜单并处理用户输入,直到用户选择退出。这比原始问题中 return startPanel(); 的递归调用更健壮,避免了潜在的栈溢出问题。

查看交易历史

viewTransactionHistory 方法负责遍历 transactionHistory 列表并打印出每一条记录。由于我们在 Transaction 类中重写了 toString() 方法,直接打印 Transaction 对象就能得到格式化的输出。

注意事项与进阶

  1. 内存存储的局限性: 当前方案中,transactionHistory 列表存储在程序的内存中。这意味着一旦程序关闭,所有存储的交易历史数据都将丢失。对于实际的应用程序,这通常是不可接受的。

  2. 数据持久化: 为了使数据在程序关闭后依然存在,需要将数据进行持久化存储。常见的持久化方式包括:

    • 文件存储: 将数据写入文本文件(如CSV、JSON、XML)或二进制文件。这适用于数据量较小、结构相对简单的情况。
    • 数据库存储: 使用关系型数据库(如MySQL, PostgreSQL, SQLite)或NoSQL数据库(如MongoDB)。这是企业级应用中最常用的方式,提供了强大的数据管理、查询、事务和并发控制能力。Java通常通过JDBC(Java Database Connectivity)或其他ORM(Object-Relational Mapping)框架(如Hibernate, MyBatis)与数据库交互。
  3. 并发安全: 如果你的应用程序是多线程的,并且多个线程可能同时尝试修改 transactionHistory 列表(例如,多个用户同时进行

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

668

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

247

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

515

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

256

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

532

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

601

2023.08.14

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 811人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号