首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JavaFX:使用MySQL数据库中的数据填充ComboBox,StringConverter打破组合框

JavaFX是一个用于构建富客户端应用程序的开发工具包。它提供了丰富的图形化用户界面(GUI)组件和功能,可以轻松创建具有各种交互性和视觉效果的应用程序。

MySQL是一种流行的关系型数据库管理系统(RDBMS),它提供了可靠的数据存储和高效的数据检索功能。

ComboBox是JavaFX中的一个UI控件,它允许用户从预定义的选项列表中选择一个值。在这个问题中,我们需要使用MySQL数据库中的数据来填充ComboBox。

为了实现这个目标,我们可以使用JavaFX提供的StringConverter接口来处理ComboBox中的数据。StringConverter接口定义了将对象转换为字符串表示形式以及将字符串表示形式转换回对象的方法。

以下是一个示例代码,演示如何使用MySQL数据库中的数据填充ComboBox并使用StringConverter打破组合框:

代码语言:txt
复制
import javafx.application.Application;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.scene.Scene;
import javafx.scene.control.ComboBox;
import javafx.scene.layout.VBox;
import javafx.stage.Stage;
import javafx.util.StringConverter;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class ComboBoxExample extends Application {

    private static final String DB_URL = "jdbc:mysql://localhost:3306/mydatabase";
    private static final String DB_USERNAME = "username";
    private static final String DB_PASSWORD = "password";

    public static void main(String[] args) {
        launch(args);
    }

    @Override
    public void start(Stage primaryStage) {
        ComboBox<String> comboBox = new ComboBox<>();
        comboBox.setConverter(new StringConverter<String>() {
            @Override
            public String toString(String object) {
                return object; // 将对象转换为字符串
            }

            @Override
            public String fromString(String string) {
                return string; // 将字符串转换为对象
            }
        });

        try {
            Connection connection = DriverManager.getConnection(DB_URL, DB_USERNAME, DB_PASSWORD);
            Statement statement = connection.createStatement();
            ResultSet resultSet = statement.executeQuery("SELECT name FROM mytable");

            ObservableList<String> options = FXCollections.observableArrayList();
            while (resultSet.next()) {
                String name = resultSet.getString("name");
                options.add(name);
            }

            comboBox.setItems(options);
        } catch (Exception e) {
            e.printStackTrace();
        }

        VBox root = new VBox(comboBox);
        Scene scene = new Scene(root, 200, 200);
        primaryStage.setScene(scene);
        primaryStage.show();
    }
}

在上面的代码中,我们首先创建了一个ComboBox对象,并设置了一个StringConverter实例作为其转换器。然后,我们使用JDBC连接到MySQL数据库,并执行一个查询来获取数据。将查询结果存储在ObservableList中,并将其设置为ComboBox的选项列表。

最后,我们创建了一个JavaFX的场景,并将ComboBox添加到其中。

请注意,上述代码中的DB_URL、DB_USERNAME和DB_PASSWORD应该替换为实际的数据库连接信息。

推荐的腾讯云相关产品和产品介绍链接地址:

  • 云数据库 MySQL:https://cloud.tencent.com/product/cdb_mysql
  • 云服务器 CVM:https://cloud.tencent.com/product/cvm
  • 云数据库 TencentDB for MySQL:https://cloud.tencent.com/product/tencentdb_mysql
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

JavaSwing_8.1:焦点事件及其监听器 - FocusEvent、FocusListener

低级别事件指示Component已获得或失去输入焦点。 由组件生成此低级别事件(如一个TextField)。 该事件被传递给每一个FocusListener或FocusAdapter注册,以接收使用组件的此类事件对象addFocusListener方法。 ( FocusAdapter对象实现FocusListener接口。)每个此类侦听器对象获取此FocusEvent当事件发生时。 有两个焦点事件级别:持久性和暂时性的。 永久焦点改变事件发生时焦点直接移动从一个组件到另一个,例如通过到requestFocus的(呼叫)或作为用户使用TAB键遍历组件。 当暂时丢失焦点的组件的另一个操作,比如释放Window或拖动滚动条的间接结果一时焦点变化的事件发生。 在这种情况下,原来的聚焦状态将被自动一旦操作完成恢复,或者,对于窗口失活的情况下,当窗口被重新激活。 永久和临时焦点事件使用FOCUS_GAINED和FOCUS_LOST事件id传递; 水平可以使用isTemporary()方法的事件区分开来。 如果未指定的行为将导致的id任何特定的参数FocusEvent实例不是从范围FOCUS_FIRST到FOCUS_LAST

01
领券