十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
沒有特別的優(yōu)勢(shì),就像一個(gè)注釋一樣。這意味著函數(shù)不會(huì)拋出異常,僅此而已。如果你有一個(gè)函數(shù),但你自己寫,它是由你的同事或其他人寫的。函數(shù)的作者在函數(shù)后面加了一個(gè)throw(),就是告訴大家“這個(gè)函數(shù)不拋出異常,catch是沒有必要的”
我有10年的開發(fā)和培訓(xùn)經(jīng)驗(yàn),其間我經(jīng)歷了JavaWeb、Android、H5、大數(shù)據(jù)、PHP等多個(gè)不同的發(fā)展方向,同時(shí)也做軟件培訓(xùn)公司的黃金講師,很有興趣回答你的問題。
您已經(jīng)清楚地解釋了這個(gè)問題中的要求,“一個(gè)查詢方法應(yīng)該返回一條記錄,但是可以找到多條記錄”!也就是說,您的查詢應(yīng)該只有一個(gè)結(jié)果,但此時(shí)或某個(gè)時(shí)候,會(huì)有多個(gè)結(jié)果,這意味著您的業(yè)務(wù)接口可能不滿足冪等性的要求。根據(jù)冪等設(shè)計(jì)原理,無論怎樣查找,只要參數(shù)相同,返回的結(jié)果應(yīng)該是相同的。
那么如何解決這個(gè)問題并拋出異常呢?返回到幾個(gè)中的第一個(gè)?
我認(rèn)為這不是一個(gè)完美的解決方案。
這對(duì)某些人來說是一個(gè)解決方案,但是問題解決了嗎?一點(diǎn)也不!問題仍然存在。下次觸發(fā)此條件時(shí),仍將引發(fā)異常。就像說森林里有一只老虎。有一天,它吃人,然后你不解決老虎的問題。你只是在森林里掛了一塊牌子,上面寫著:小心,里面有老虎!這…
事實(shí)上,這不是一個(gè)好辦法。也許只有一件東西應(yīng)該被退回。為什么要查詢多個(gè)項(xiàng)目?您是否檢查了數(shù)據(jù)庫中數(shù)據(jù)的唯一性?你不覺得每次查詢多個(gè)結(jié)果然后得到第一個(gè)數(shù)據(jù)效率很低嗎?
所以我們應(yīng)該從根本上解決問題!為什么會(huì)產(chǎn)生多個(gè)數(shù)據(jù)?如果要手動(dòng)檢查數(shù)據(jù),則需要手動(dòng)檢查。如果要鎖定它,應(yīng)該盡大努力確保輸入?yún)?shù)相同,結(jié)果相同
做程序時(shí),如果某個(gè)查詢方法應(yīng)當(dāng)返回一條記錄,但是查出來多條,是拋異常好還是從多條中取第一條好?使用trycatchblock打包將產(chǎn)生異常的程序塊。當(dāng)異常發(fā)生時(shí),它將根據(jù)需要輸入catch并顯示異常信息
例如:
try
{DBUtil.ExecuteSql文件(sql,paras)
}
catch(異常e)
{控制臺(tái)。寫入(e)//e是異常信息對(duì)象
}