Java中使用JDBC从SqlServer获取到的ResultSet结果集为空

4 篇文章 0 订阅
4 篇文章 0 订阅

我在Servlet中使用JDBC连接SqlServer后
从数据库进行了查询操作
但得到的ResultSet结果集在调用时出现了空指针的异常

这是因为获取到的ResultSet结果集的第0个结果是为空的
从数据库中获取的数据是从第1个开始排列的
只需调用next()方法就可以解决了

示例代码:

package sqlserver.selecter.meal;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class Sqlserver_All_Power_Selecter {

    protected Statement statement;
    protected ResultSet result;

    protected String sql_begin = "select * from ";
    protected String sql_middle = " where meal_id = '";
    protected String sql_end = "'";

    public Sqlserver_All_Power_Selecter(Statement statement){

        this.statement = statement;
    }

    public ResultSet selectTbo(String Tbo, String meal_id){


        try {
            String sql = sql_begin + Tbo + sql_middle + meal_id + sql_end;
            result = statement.executeQuery(sql);
            System.out.println("已从" + Tbo + "中获取到药膳" + meal_id + "的数据");
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        try {
            result.next();
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        return result;

    }
}
您可以使用JavaJDBC驱动程序来连接到SQL Server数据库并执行查询以获取航班列表。然后,您可以使用Java的GUI库(如Swing或JavaFX)来创建一个表格,并动态地将查询结果添加到表格。 以下是一个简单的示例代码,演示如何实现这个功能: ```java import java.sql.*; public class FlightTableExample { public static void main(String[] args) { String url = "jdbc:sqlserver://localhost:1433;databaseName=YourDatabase"; String username = "YourUsername"; String password = "YourPassword"; try (Connection conn = DriverManager.getConnection(url, username, password)) { String sql = "SELECT * FROM flights"; Statement statement = conn.createStatement(); ResultSet resultSet = statement.executeQuery(sql); // 创建表格 javax.swing.JTable table = new javax.swing.JTable(); // 创建表格模型 javax.swing.table.DefaultTableModel tableModel = new javax.swing.table.DefaultTableModel(); // 获取列名 ResultSetMetaData metaData = resultSet.getMetaData(); int columnCount = metaData.getColumnCount(); for (int i = 1; i <= columnCount; i++) { tableModel.addColumn(metaData.getColumnName(i)); } // 添加数据到表格模型 while (resultSet.next()) { Object[] row = new Object[columnCount]; for (int i = 1; i <= columnCount; i++) { row[i - 1] = resultSet.getObject(i); } tableModel.addRow(row); } // 设置表格的数据模型 table.setModel(tableModel); // 创建一个滚动面板,将表格放入其 javax.swing.JScrollPane scrollPane = new javax.swing.JScrollPane(table); // 创建一个窗口并显示表格 javax.swing.JFrame frame = new javax.swing.JFrame(); frame.add(scrollPane); frame.setDefaultCloseOperation(javax.swing.JFrame.EXIT_ON_CLOSE); frame.pack(); frame.setVisible(true); } catch (SQLException e) { e.printStackTrace(); } } } ``` 请注意,您需要将示例代码的`url`,`username`和`password`替换为您自己的SQL Server数据库的连接信息。此外,您可能还需要根据您的数据库架构和表结构进行相应的更改。 这个示例代码使用了Swing库来创建一个简单的窗口,并将查询结果动态地添加到表格。您可以根据自己的需求进行更多的定制和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值