亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

為什么 ResultSet 不從 MySQL 返回數據

為什么 ResultSet 不從 MySQL 返回數據

aluckdog 2023-11-10 16:03:35
我想從 MySQL 數據庫獲取圖像并顯示在 a 中JLabel,但是當我執行查詢并嘗試從 a 中獲取字節時,ResultSet它返回一個空數組。我測試了連接,它正在工作,測試了查詢,它也工作了。try {    conn = getConnection();    pst = conn.prepareStatement("select * from imagem where serial_imagem = 123658");    rs = pst.executeQuery()    if (rs.next()) {        image = rs.getBytes("img_imagem");    }}catch (Exception e) {    e.printStackTrace();}  
查看完整描述

1 回答

?
慕妹3146593

TA貢獻1820條經驗 獲得超9個贊

代碼不會關閉,因此會泄漏資源。有點丑陋的 Try-With-Resources 語法確保關閉連接、語句和結果集,即使在返回/異常時也是如此。


可以使用Optional明確表明圖像是否在表中找到。


Optional.of還保證數據庫中的字段不能包含 SQL NULL 值。


Optional<byte[]> loadImageFromDatabase(String imageM) throws SQLException {

   String sql = "select img_imagem from imagem where serial_imagem = ?";

   try (Connection conn = getConnection();

           PreparedStatement pst = conn.prepareStatement(sql)) {

       pst.setString(1, imageM);

       try (ResultSet rs = pst.executeQuery()) {

           if (rs.next()) {

               return Optional.of(rs.getBytes(1)); // ofNullable

           } else {

               return Optional.empty();

           }

       }

    }

}

用法:


    try {

        Optional<byte[]> img = loadImageFromDatabase(jtextField1.getText().trim());

        img.ifPresent(image -> {

                ...

            });

    } catch (SQLException e) {

還有一點還是要說明的是,我個人并不經常使用ResultSet.getBytes,但還是有的getInputStream。取決于圖像大小和創建代碼。


查看完整回答
反對 回復 2023-11-10
  • 1 回答
  • 0 關注
  • 153 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號