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

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

Java 在發(fā)生 SQLException 時(shí)響應(yīng)應(yīng)用程序

Java 在發(fā)生 SQLException 時(shí)響應(yīng)應(yīng)用程序

守著星空守著你 2023-05-17 14:38:27
我目前有一個(gè)數(shù)據(jù)庫(kù)類,其中包含我從 SQL 數(shù)據(jù)庫(kù)檢索數(shù)據(jù)的所有方法。一個(gè)方法看起來(lái)像:@Overridepublic void setGlobalSetting(Setting setting) {    if(setting.getId() == 0) {        try {            PreparedStatement ps = this.conn.prepareStatement("INSERT INTO BotSettings(guildId, settingKey, settingValue) VALUES(?, ?, ?)");            ps.setLong(1, -1);            ps.setString(2, setting.getKey());            ps.setString(3, setting.getValue());            ps.executeUpdate();        } catch (SQLException e) {            e.printStackTrace();        }    } else {        try {            PreparedStatement ps = this.conn.prepareStatement("UPDATE BotSettings SET settingValue = ? WHERE guildId = ? AND settingKey = ?");            ps.setString(1, setting.getValue());            ps.setLong(2, -1);            ps.setString(3, setting.getKey());            ps.executeUpdate();        } catch (SQLException e) {            e.printStackTrace();        }    }}問(wèn)題是當(dāng) SQLException 發(fā)生時(shí)我無(wú)法告訴我的應(yīng)用程序,因此應(yīng)用程序可能會(huì)響應(yīng)用戶應(yīng)用程序未能保存數(shù)據(jù)。我怎樣才能實(shí)現(xiàn)一個(gè)可以告訴應(yīng)用程序失敗的方法。我想到了用Consumer來(lái)告訴成功和失敗,但是還有其他方法嗎?
查看完整描述

1 回答

?
慕尼黑的夜晚無(wú)繁華

TA貢獻(xiàn)1864條經(jīng)驗(yàn) 獲得超6個(gè)贊

我想到了用Consumer來(lái)告訴成功和失敗,但是還有其他方法嗎?


你不需要趕上SQLException??梢韵胂螅梢宰屗鼈鞑サ娇梢赃m當(dāng)處理的更高級(jí)別。


或者,您可以拋出一個(gè)新的異常。例如:


public void setGlobalSetting(Setting setting) throws MyException {

    if(setting.getId() == 0) {

        try {

            ...

            ps.executeUpdate();

        } catch (SQLException e) {

            throw new MyException("Cannot set setting due to database error", e);

        }

    } else {

        ...

    }

}

在此上下文中可能存在一個(gè)合理的拋出異常。如果不是,請(qǐng)聲明您自己的異常類。


如果您認(rèn)為調(diào)用者需要嘗試從中恢復(fù),則檢查異常是合適的。否則使用未經(jīng)檢查的異常。


要點(diǎn)是你的代碼不應(yīng)該捕獲異常,除非它能夠處理它。打印堆棧跟蹤并繼續(xù)執(zhí)行很少是處理異常的正確方法。


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

添加回答

舉報(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)