java中怎么使用swing连接数据库

102次阅读
没有评论

共计 2301 个字符,预计需要花费 6 分钟才能阅读完成。

在 Java 中使用 Swing 连接 数据库,需要借助 JDBC(Java Database Connectivity)技术。以下是一个简单的例子,演示了如何使用 Swing 和 JDBC 连接MySQL 数据库

1. 导入必要的包:
java
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
import java.sql.*;

2. 创建 Swing 界面:
java
public class DatabaseConnection extends JFrame {

   private JTextField tfName;

   private JTextArea taResult;

   private JButton btnConnect;

   public DatabaseConnection() {

       // 设置窗口标题

       super("Database Connection");

       

       // 创建组件

       tfName = new JTextField(20);

       taResult = new JTextArea();

       btnConnect = new JButton("Connect");

       

       // 添加事件监听器

       btnConnect.addActionListener(new ActionListener() {

           @Override

           public void actionPerformed(ActionEvent e) {

               connectToDatabase();

           }

       });

       

       // 创建面板并添加组件

       JPanel panel = new JPanel();

       panel.add(new JLabel("Name:"));

       panel.add(tfName);

       panel.add(btnConnect);

       

       // 设置文本区域属性

       taResult.setEditable(false);

       taResult.setLineWrap(true);

       

       // 添加组件到窗口

       Container container = getContentPane();

       container.setLayout(new BorderLayout());

       container.add(panel, BorderLayout.NORTH);

       container.add(new JScrollPane(taResult), BorderLayout.CENTER);

       

       // 设置窗口大小和可见性

       setSize(400, 300);

       setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

       setVisible(true);

   }

   private void connectToDatabase() {

       // 获取用户名

       String name = tfName.getText();

       

       // 连接数据库

       try {

           // 加载数据库驱动

           Class.forName("com.mysql.jdbc.Driver");

           

           // 创建连接

           Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydatabase", "username", "password");

           

           // 执行查询

           Statement stmt = con.createStatement();

           ResultSet rs = stmt.executeQuery("SELECT * FROM users WHERE name = '" + name + "'");

           

           // 处理结果集

           while (rs.next()) {

               int id = rs.getInt("id");

               String resultName = rs.getString("name");

               String email = rs.getString("email");

               taResult.append("ID: " + id + ", Name: " + resultName + ", Email: " + email + "\n");

           }

           

           // 关闭连接

           rs.close();

           stmt.close();

           con.close();

       } catch (Exception e) {

           e.printStackTrace();

       }

   }

   public static void main(String[] args) {

       new DatabaseConnection();

   }
}

在上述代码中,通过 JDBC 加载 MySQL 数据库驱动,使用 DriverManager.getConnection() 方法连接数据库,然后使用查询语句执行查询,并处理结果集。最后关闭连接。

注意:上述代码中的数据库连接字符串(jdbc:mysql://localhost:3306/mydatabase)需要根据实际情况进行修改,以及数据库用户名和密码("username", "password")。

丸趣 TV 网 – 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-21发表,共计2301字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)