java系統(tǒng)業(yè)務(wù)日志表記錄 java開發(fā)怎么做日志功能就是記錄用戶每一步的操作具體做什么了?
java開發(fā)怎么做日志功能就是記錄用戶每一步的操作具體做什么了?具體來說,挺麻煩的。我給你一個想法:如果你想記錄和查看操作日志,你必須將操作日志直接保存到數(shù)據(jù)庫中。日志管理模塊,由于上面有日志記錄,做
java開發(fā)怎么做日志功能就是記錄用戶每一步的操作具體做什么了?
具體來說,挺麻煩的。我給你一個想法:如果你想記錄和查看操作日志,你必須將操作日志直接保存到數(shù)據(jù)庫中。日志管理模塊,由于上面有日志記錄,做一個刪除功能應(yīng)該很容易做到。我不想詳細(xì)說明。最重要的是:如何記錄日志。其思想是:首先分析哪些日志需要記錄,一般記錄數(shù)據(jù)的添加、修改和刪除操作。此外,還應(yīng)記錄一些特殊的查詢操作。其實,怎么錄。一開始,我們討論了日志存儲。現(xiàn)在的問題是,什么時候才能做出一個邏輯。這個時間通常是訪客啟動操作的時候。例如,開始在相應(yīng)的方法體中記錄操作、servlet或控制器。當(dāng)然,我們需要編寫日志存儲的邏輯。其實,這個日志管理是一個比較完整的功能塊,甚至是一個很小的系統(tǒng)。還有許多小細(xì)節(jié)和解決方案。有了想法,如何實現(xiàn)就要看情況了。
做程序時,如果某個查詢方法應(yīng)當(dāng)返回一條記錄,但是查出來多條,是拋異常好還是從多條中取第一條好?
我有10年的開發(fā)和培訓(xùn)經(jīng)驗。在此期間,我經(jīng)歷了Java、web、Android、H5、大數(shù)據(jù)、PHP等不同的發(fā)展方向。我也是軟件培訓(xùn)公司的金牌講師。我對回答這個問題很感興趣。
您已經(jīng)清楚地解釋了這個問題中的要求,“一個查詢方法應(yīng)該返回一條記錄,但是可以找到多條記錄”!也就是說,您的查詢應(yīng)該只有一個結(jié)果,但此時或某個時候,會有多個結(jié)果,這意味著您的業(yè)務(wù)接口可能不滿足冪等性的要求。根據(jù)冪等設(shè)計原理,無論怎樣查找,只要參數(shù)相同,返回的結(jié)果應(yīng)該是相同的。
那么如何解決這個問題并拋出異常呢?返回到幾個中的第一個?
我認(rèn)為這不是一個完美的解決方案。
這對某些人來說是一個解決方案,但是問題解決了嗎?一點也不!問題仍然存在。下次觸發(fā)此條件時,仍將引發(fā)異常。就像說森林里有一只老虎。有一天,它吃人,然后你不解決老虎的問題。你只是在森林里掛了一塊牌子,上面寫著:小心,里面有老虎!這…
事實上,這不是一個好辦法。也許只有一件東西應(yīng)該被退回。為什么要查詢多個項目?您是否檢查了數(shù)據(jù)庫中數(shù)據(jù)的唯一性?你不覺得每次查詢多個結(jié)果然后得到第一個數(shù)據(jù)效率很低嗎?
所以我們應(yīng)該從根本上解決問題!為什么會產(chǎn)生多個數(shù)據(jù)?如果要手動檢查數(shù)據(jù),則需要手動檢查。如果要鎖定它,應(yīng)該盡最大努力確保輸入?yún)?shù)相同,結(jié)果相同!