中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

java中怎么使用swing連接數據庫

小億
155
2023-08-25 09:24:10
欄目: 編程語言

在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"`)。

0
南郑县| 东乌| 青铜峡市| 定远县| 高安市| 扶绥县| 梅州市| 漳平市| 盐津县| 锡林郭勒盟| 邻水| 金堂县| 邳州市| 定州市| 永靖县| 砚山县| 临洮县| 湛江市| 遂昌县| 顺昌县| 庄浪县| 来凤县| 郁南县| 神木县| 射阳县| 锡林郭勒盟| 星子县| 灌南县| 新兴县| 亚东县| 左贡县| 屏南县| 越西县| 巴林右旗| 永丰县| 儋州市| 特克斯县| 韶山市| 广德县| 工布江达县| 惠来县|