零基础直接上手java跨平台桌面程序,使用javafx(六)查询sqlite数据显示到TableView中

我们使用jdbc查询sqlite的一个表显示到TableView中

在hello-view的onMouseClicked里面填上"openclick2",然后在HelloController写上openclick2的相关代码@FXML protected void openclick2() { }。我们要先配置好sqlite的jdbc驱动(略)。openclick2的代码如下:

java 复制代码
 protected void openclick2()
    {
        FileChooser fileChooser = new FileChooser();
        fileChooser.setTitle("文件sqlite");
        fileChooser.getExtensionFilters().add(new FileChooser.ExtensionFilter("sqlite", "*.db", "*.db3"));
        // 设置文件选择框的初始目录(可选)
        //fileChooser.setInitialDirectory(new File(System.getProperty("user.home")));
        // 显示文件选择框并获取所选文件
        File selectedFile = fileChooser.showOpenDialog(new Stage());

        if (selectedFile != null) {
            String fileName = selectedFile.getName();
            String databaseUrl = "jdbc:sqlite:" + selectedFile.getPath();
            try (Connection connection = DriverManager.getConnection(databaseUrl)) {
                Statement statement = connection.createStatement();
                ResultSet resultSet = statement.executeQuery("SELECT * FROM sheet1");

                // 清除旧的列
                TableView1.getColumns().clear();

                // 获取元数据以动态创建列
                ResultSetMetaData metaData = resultSet.getMetaData();
                int columnCount = metaData.getColumnCount();
                for (int i = 1; i <= columnCount; i++) {
                    final int columnIndex = i;
                    TableColumn<ObservableList<Object>, Object> column = new TableColumn<>(metaData.getColumnName(i));
                    column.setCellValueFactory(param -> new javafx.beans.property.SimpleObjectProperty<>(param.getValue().get(columnIndex - 1)));
                    TableView1.getColumns().add(column);
                }

                // 加载数据到TableView
                ObservableList<ObservableList<Object>> data = FXCollections.observableArrayList();
                while (resultSet.next()) {
                    ObservableList<Object> row = FXCollections.observableArrayList();
                    for (int i = 1; i <= columnCount; i++) {
                        row.add(resultSet.getObject(i));
                    }
                    data.add(row);
                }
                TableView1.setItems(data);

            } catch (Exception e) {
                e.printStackTrace();
            }
        }

    }

我们可以看到jdbc取数据的语句非常的简单,比c#的ado还要简单。

复制代码
try (Connection connection = DriverManager.getConnection(databaseUrl)) {
    Statement statement = connection.createStatement();
    ResultSet resultSet = statement.executeQuery("SELECT * FROM sheet1");}

Connection 对象:Connection 对象代表与数据库的连接。要连接到数据库,您需要使用 DriverManager 类的 getConnection 方法,该方法接收数据库URL、用户名和密码作为参数。

Statement 对象:Statement 对象用于执行静态SQL语句并返回其生成的结果。

ResultSet 对象:ResultSet 对象代表SQL查询的结果集,通常是通过执行 Statement 对象生成的。

运行效果如下:

相关推荐
Lyyaoo.22 分钟前
【JAVA基础面经】JVM的内存模型
java·开发语言·jvm
杨凯凡23 分钟前
【017】泛型与通配符:API 设计里怎么用省心
java·开发语言
Java后端的Ai之路28 分钟前
Text-to-SQL与智能问数完全指南:基本概念、核心原理、Python实战教学及企业项目落地
数据库·python·sql·text-to-sql·智能问数
Elastic 中国社区官方博客28 分钟前
Prometheus Remote Write 在 Elasticsearch 中的摄取原理
大数据·数据库·elasticsearch·搜索引擎·信息可视化·全文检索·prometheus
IT利刃出鞘30 分钟前
Spring工具类--ObjectUtils的使用
java·后端·spring
2601_9498166831 分钟前
Spring boot启动原理及相关组件
数据库·spring boot·后端
2301_7826591832 分钟前
如何使用Navicat连接云端MariaDB_白名单与实例配置
jvm·数据库·python
2301_803875617 小时前
PHP 中处理会话数组时的类型错误解析与修复指南
jvm·数据库·python
m0_743623927 小时前
c++如何批量修改文件后缀名_std--filesystem--replace_extension【实战】
jvm·数据库·python
MY_TEUCK7 小时前
Sealos 平台部署实战指南:结合 Cursor 与版本发布流程
java·人工智能·学习·aigc