第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

為什么 ResultSet 不從 MySQL 返回?cái)?shù)據(jù)

為什么 ResultSet 不從 MySQL 返回?cái)?shù)據(jù)

aluckdog 2023-11-10 16:03:35
我想從 MySQL 數(shù)據(jù)庫獲取圖像并顯示在 a 中JLabel,但是當(dāng)我執(zhí)行查詢并嘗試從 a 中獲取字節(jié)時(shí),ResultSet它返回一個(gè)空數(shù)組。我測(cè)試了連接,它正在工作,測(cè)試了查詢,它也工作了。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貢獻(xiàn)1820條經(jīng)驗(yàn) 獲得超9個(gè)贊

代碼不會(huì)關(guān)閉,因此會(huì)泄漏資源。有點(diǎn)丑陋的 Try-With-Resources 語法確保關(guān)閉連接、語句和結(jié)果集,即使在返回/異常時(shí)也是如此。


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


Optional.of還保證數(shù)據(jù)庫中的字段不能包含 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) {

還有一點(diǎn)還是要說明的是,我個(gè)人并不經(jīng)常使用ResultSet.getBytes,但還是有的getInputStream。取決于圖像大小和創(chuàng)建代碼。


查看完整回答
反對(duì) 回復(fù) 2023-11-10
  • 1 回答
  • 0 關(guān)注
  • 150 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)