给出代码 客户管理模块:使用Java的GUI类实现客户信息的展示及增删改查操作。使用JDBC与数据库进行交互

时间: 2024-03-12 11:47:07 浏览: 18
以下是一个简单的客户管理模块的代码示例,使用Java的GUI类实现客户信息的展示及增删改查操作,同时使用JDBC与数据库进行交互。这个示例中使用了MySQL数据库,所以需要先安装MySQL数据库,并创建一个名为“customers”的数据库,并在其中创建一个名为“customer_info”的表,表结构如下: | Field | Type | Null | Key | Default | Extra | |-------------|--------------|-------|-----|---------|----------------| | id | int(11) | NO | PRI | NULL | auto_increment | | name | varchar(255)| YES | | NULL | | | email | varchar(255)| YES | | NULL | | | phone | varchar(255)| YES | | NULL | | | address | varchar(255)| YES | | NULL | | | created_at | timestamp | NO | | NULL | | | updated_at | timestamp | NO | | NULL | | 代码如下: ```java import java.awt.*; import java.awt.event.*; import javax.swing.*; import java.sql.*; public class CustomerManagementSystem extends JFrame implements ActionListener { private JLabel nameLabel, emailLabel, phoneLabel, addressLabel; private JTextField nameField, emailField, phoneField, addressField; private JButton addButton, updateButton, deleteButton, searchButton; private JTable table; private JScrollPane scrollPane; private Connection connection; private PreparedStatement preparedStatement; public CustomerManagementSystem() { setTitle("Customer Management System"); setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); setSize(800, 500); nameLabel = new JLabel("Name:"); emailLabel = new JLabel("Email:"); phoneLabel = new JLabel("Phone:"); addressLabel = new JLabel("Address:"); nameField = new JTextField(20); emailField = new JTextField(20); phoneField = new JTextField(20); addressField = new JTextField(20); addButton = new JButton("Add"); updateButton = new JButton("Update"); deleteButton = new JButton("Delete"); searchButton = new JButton("Search"); addButton.addActionListener(this); updateButton.addActionListener(this); deleteButton.addActionListener(this); searchButton.addActionListener(this); JPanel inputPanel = new JPanel(new GridLayout(4, 2)); inputPanel.add(nameLabel); inputPanel.add(nameField); inputPanel.add(emailLabel); inputPanel.add(emailField); inputPanel.add(phoneLabel); inputPanel.add(phoneField); inputPanel.add(addressLabel); inputPanel.add(addressField); JPanel buttonPanel = new JPanel(new GridLayout(1, 4)); buttonPanel.add(addButton); buttonPanel.add(updateButton); buttonPanel.add(deleteButton); buttonPanel.add(searchButton); JPanel formPanel = new JPanel(new BorderLayout()); formPanel.add(inputPanel, BorderLayout.CENTER); formPanel.add(buttonPanel, BorderLayout.SOUTH); table = new JTable(); scrollPane = new JScrollPane(table); JPanel panel = new JPanel(new BorderLayout()); panel.add(formPanel, BorderLayout.NORTH); panel.add(scrollPane, BorderLayout.CENTER); add(panel); try { Class.forName("com.mysql.jdbc.Driver"); connection = DriverManager.getConnection("jdbc:mysql://localhost/customers", "root", ""); } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } updateTable(); } private void updateTable() { try { preparedStatement = connection.prepareStatement("SELECT * FROM customer_info"); ResultSet resultSet = preparedStatement.executeQuery(); table.setModel(DbUtils.resultSetToTableModel(resultSet)); } catch (SQLException e) { e.printStackTrace(); } } private void clearFields() { nameField.setText(""); emailField.setText(""); phoneField.setText(""); addressField.setText(""); } private void addCustomer() { try { preparedStatement = connection.prepareStatement("INSERT INTO customer_info (name, email, phone, address, created_at, updated_at) VALUES (?, ?, ?, ?, NOW(), NOW())"); preparedStatement.setString(1, nameField.getText()); preparedStatement.setString(2, emailField.getText()); preparedStatement.setString(3, phoneField.getText()); preparedStatement.setString(4, addressField.getText()); int result = preparedStatement.executeUpdate(); if (result > 0) { JOptionPane.showMessageDialog(this, "Customer added successfully!"); } else { JOptionPane.showMessageDialog(this, "Error adding customer!"); } clearFields(); updateTable(); } catch (SQLException e) { e.printStackTrace(); } } private void updateCustomer() { int row = table.getSelectedRow(); if (row == -1) { JOptionPane.showMessageDialog(this, "Please select a customer to update!"); } else { try { preparedStatement = connection.prepareStatement("UPDATE customer_info SET name = ?, email = ?, phone = ?, address = ?, updated_at = NOW() WHERE id = ?"); preparedStatement.setString(1, nameField.getText()); preparedStatement.setString(2, emailField.getText()); preparedStatement.setString(3, phoneField.getText()); preparedStatement.setString(4, addressField.getText()); preparedStatement.setInt(5, (int) table.getValueAt(row, 0)); int result = preparedStatement.executeUpdate(); if (result > 0) { JOptionPane.showMessageDialog(this, "Customer updated successfully!"); } else { JOptionPane.showMessageDialog(this, "Error updating customer!"); } clearFields(); updateTable(); } catch (SQLException e) { e.printStackTrace(); } } } private void deleteCustomer() { int row = table.getSelectedRow(); if (row == -1) { JOptionPane.showMessageDialog(this, "Please select a customer to delete!"); } else { int result = JOptionPane.showConfirmDialog(this, "Are you sure you want to delete this customer?", "Delete Customer", JOptionPane.YES_NO_OPTION); if (result == JOptionPane.YES_OPTION) { try { preparedStatement = connection.prepareStatement("DELETE FROM customer_info WHERE id = ?"); preparedStatement.setInt(1, (int) table.getValueAt(row, 0)); int deleteResult = preparedStatement.executeUpdate(); if (deleteResult > 0) { JOptionPane.showMessageDialog(this, "Customer deleted successfully!"); } else { JOptionPane.showMessageDialog(this, "Error deleting customer!"); } clearFields(); updateTable(); } catch (SQLException e) { e.printStackTrace(); } } } } private void searchCustomer() { String name = nameField.getText(); String email = emailField.getText(); String phone = phoneField.getText(); String address = addressField.getText(); try { String sql = "SELECT * FROM customer_info WHERE 1=1"; if (!name.isEmpty()) { sql += " AND name LIKE '%" + name + "%'"; } if (!email.isEmpty()) { sql += " AND email LIKE '%" + email + "%'"; } if (!phone.isEmpty()) { sql += " AND phone LIKE '%" + phone + "%'"; } if (!address.isEmpty()) { sql += " AND address LIKE '%" + address + "%'"; } preparedStatement = connection.prepareStatement(sql); ResultSet resultSet = preparedStatement.executeQuery(); table.setModel(DbUtils.resultSetToTableModel(resultSet)); } catch (SQLException e) { e.printStackTrace(); } } public void actionPerformed(ActionEvent event) { if (event.getSource() == addButton) { addCustomer(); } else if (event.getSource() == updateButton) { updateCustomer(); } else if (event.getSource() == deleteButton) { deleteCustomer(); } else if (event.getSource() == searchButton) { searchCustomer(); } } public static void main(String[] args) { CustomerManagementSystem cms = new CustomerManagementSystem(); cms.setVisible(true); } } ``` 这个代码示例中,我们使用了Java的GUI类来实现客户管理模块的用户界面,包括文本框、标签、按钮和表格等控件。我们还使用了JDBC来与MySQL数据库进行交互,包括查询、插入、更新和删除等操作。在程序运行时,我们首先需要建立与数据库的连接,并在表格中显示所有客户的信息。当用户点击“添加”按钮时,我们会将用户在文本框中输入的客户信息插入到数据库中,并在表格中添加一行新的记录。当用户点击“更新”按钮时,我们会更新表格中被选中的记录对应的数据库记录。当用户点击“删除”按钮时,我们会删除表格中被选中的记录对应的数据库记录。当用户点击“搜索”按钮时,我们会根据用户在文本框中输入的关键字查询数据库,并在表格中显示查询结果。

相关推荐

最新推荐

recommend-type

JDBC+GUI实现简单学生管理系统

主要为大家详细介绍了JDBC+GUI实现简单学生管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

python图形开发GUI库pyqt5的详细使用方法及各控件的属性与方法

主要介绍了python图形开发GUI库pyqt5的详细使用方法及各控件的属性与方法,需要的朋友可以参考下
recommend-type

Python实现GUI学生信息管理系统

主要介绍了Python实现GUI学生信息管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

python GUI库图形界面开发之PyQt5树形结构控件QTreeWidget详细使用方法与实例

主要介绍了python GUI库图形界面开发PyQt5树形结构控件QTreeWidget详细使用方法与实例,需要的朋友可以参考下
recommend-type

Java将数据库的数据展示到JTable表格中

Mysql数据库内容展示写死版 import javax.swing.*; import java.awt.*; import java.sql.*; public class XieSiBan extends JFrame { public static void main(String[] args) { try { // 加载MySql驱动 Class....
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

2. 通过python绘制y=e-xsin(2πx)图像

可以使用matplotlib库来绘制这个函数的图像。以下是一段示例代码: ```python import numpy as np import matplotlib.pyplot as plt def func(x): return np.exp(-x) * np.sin(2 * np.pi * x) x = np.linspace(0, 5, 500) y = func(x) plt.plot(x, y) plt.xlabel('x') plt.ylabel('y') plt.title('y = e^{-x} sin(2πx)') plt.show() ``` 运行这段
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。