java組合與復(fù)用 Java Web開發(fā)中,業(yè)務(wù)邏輯寫在SQL里好還是代碼里好呢?有什么建議嗎?
Java Web開發(fā)中,業(yè)務(wù)邏輯寫在SQL里好還是代碼里好呢?有什么建議嗎?目前,大多數(shù)研發(fā)團隊都要求用代碼實現(xiàn)業(yè)務(wù)邏輯,SQL操作往往是最基本的操作。用SQL表示業(yè)務(wù)邏輯,即用存儲過程表示業(yè)務(wù)邏輯,
Java Web開發(fā)中,業(yè)務(wù)邏輯寫在SQL里好還是代碼里好呢?有什么建議嗎?
目前,大多數(shù)研發(fā)團隊都要求用代碼實現(xiàn)業(yè)務(wù)邏輯,SQL操作往往是最基本的操作。用SQL表示業(yè)務(wù)邏輯,即用存儲過程表示業(yè)務(wù)邏輯,是一種傳統(tǒng)的開發(fā)方案。
在C/s時代,很多邏輯都是通過SQL來實現(xiàn)的,主要是因為業(yè)務(wù)規(guī)模和部署方式。在早期的C/s編程時代,它通常是在非分布式環(huán)境中開發(fā)的,在大多數(shù)情況下,它不需要考慮可移植性問題。這時,使用SQL來完成業(yè)務(wù)邏輯就更方便了。
使用存儲過程來完成業(yè)務(wù)邏輯的最大優(yōu)點是性能會更好,但這也取決于業(yè)務(wù)的大小。如果業(yè)務(wù)規(guī)模過大,業(yè)績會更差。早期的數(shù)據(jù)存儲規(guī)模比較小,所以使用存儲過程比較方便。
當(dāng)前網(wǎng)絡(luò)發(fā)展已進入大數(shù)據(jù)、云計算時代,業(yè)務(wù)類型和業(yè)務(wù)規(guī)模發(fā)生了巨大變化。特別是隨著NoSQL數(shù)據(jù)庫在大數(shù)據(jù)時代的廣泛應(yīng)用,使用SQL語句來完成業(yè)務(wù)邏輯的場景越來越少。而且,目前大多數(shù)程序都是分布式的,使用SQL存儲過程處理業(yè)務(wù)邏輯非常麻煩,會導(dǎo)致整個項目的可移植性和可讀性嚴重下降。
目前,在傳統(tǒng)企業(yè)的開發(fā)團隊中,使用SQL來處理業(yè)務(wù)邏輯是相當(dāng)普遍的,因為傳統(tǒng)企業(yè)的數(shù)據(jù)庫大多還是關(guān)系數(shù)據(jù)庫,沒有可移植性的要求。這種固定的場景開發(fā)可以使用SQL來處理業(yè)務(wù)邏輯。在將來,使用SQL處理業(yè)務(wù)邏輯時會出現(xiàn)一些應(yīng)用場景,因此有必要學(xué)習(xí)如何編寫存儲過程。
Java和Python的發(fā)展,哪一個更好一些?
在我看來,它仍然是Java
1。雖然Python是近年來流行的編程語言,但它在機器學(xué)習(xí)、人工智能等領(lǐng)域得到了廣泛的應(yīng)用,我也用了半年的Python。有時候我要完成一個小任務(wù),所以我會選擇Python,因為它非常簡單。但是他的架構(gòu)不是很完美,基本的運行速度也比較慢。
2. Java一直是互聯(lián)網(wǎng)上的熱門話題。這么多年來,從最初的互聯(lián)網(wǎng)應(yīng)用到移動互聯(lián)網(wǎng)時代,生活的方方面面都離不開Java構(gòu)建的系統(tǒng)。許多公司在系統(tǒng)中使用java語言。一般來說,底層代碼不會隨意更改。所以Java工作應(yīng)該很容易找到。
下面是tiobe編程語言的最新排名。
不過,我也認為Python總有一天會超過Java,所以我建議程序員無論怎樣都應(yīng)該更多地接觸新技術(shù),只有吃了老錢,他們才會被砍掉。
寫JAVA后端代碼時邏輯混亂怎么辦?
后端代碼的復(fù)雜性通過分割和裁決來解決。首先,通過拆分項目,項目之間可以存在依賴關(guān)系,但必須是單向依賴而不是環(huán)依賴。如果存在環(huán),我們必須考慮將環(huán)依賴分解為單獨的項目來解決環(huán)依賴。
對于項目中的代碼,可以通過水平拆分和垂直拆分來降低復(fù)雜性。水平層分為控制器、服務(wù)、Dao和sqlmap,垂直層分為系統(tǒng)、biz1、biz2、Bizn,但在數(shù)據(jù)通暢連接中,水平拆分和垂直拆分相結(jié)合,如下圖所示:
通過這種分層方式,代碼層是分開的,結(jié)構(gòu)清晰。對于一些跨模塊調(diào)用的接口,如同一個數(shù)據(jù)表需要在不同的模塊中操作時,可以將該接口作為公共接口升級到上層cxmodule,對于一些可重用的、相對獨立的功能,可以在cxmodule中定義一個干凈的接口,業(yè)務(wù)邏輯可以通過在模塊的功能模塊中實現(xiàn)接口來實現(xiàn),而不需要使用spring的事務(wù)管理機制,從而降低代碼的復(fù)雜度。
java業(yè)務(wù)邏輯,寫在哪里比較好?
現(xiàn)在很多公司的開發(fā)人員都應(yīng)該采用MVC架構(gòu)。
MVC是所謂的模型、視圖、控制器。
每一層都有明確的分工。
對于簡單的項目,不管nignx如何,網(wǎng)關(guān)通常都會將請求從前端發(fā)送到后端,首先發(fā)送到控制器,然后發(fā)送到服務(wù)層,然后發(fā)送到Dao層。
這里的服務(wù)層就是所謂的業(yè)務(wù)層,專門負責(zé)業(yè)務(wù)處理操作,而Dao層則負責(zé)處理數(shù)據(jù)庫,將數(shù)據(jù)庫中的數(shù)據(jù)帶回服務(wù),經(jīng)過服務(wù)處理后返回控制器層??刂破魍ㄟ^視圖解析器解析頁面,并通過瀏覽器呈現(xiàn)頁面。
基本上,我認為答案是顯而易見的。也就是說,Java業(yè)務(wù)邏輯是在服務(wù)層編寫的。
事實上,服務(wù)層涉及接口和接口實現(xiàn)。
在編寫代碼時,我們通常為控制器定義一個調(diào)用接口。
實際上,服務(wù)接口的實現(xiàn)類應(yīng)該是編寫業(yè)務(wù)邏輯的地方。
當(dāng)然,許多公司可能有多個服務(wù)層,例如,有一個管理層繼續(xù)對數(shù)據(jù)進行特殊的業(yè)務(wù)處理。這里只是一個簡單的概述。
每個公司的每個項目根據(jù)其自身業(yè)務(wù)可能有不同的體系結(jié)構(gòu)。但本質(zhì)是一樣的。
綜上所述,業(yè)務(wù)邏輯必須作為一個獨立的層來處理,這樣便于擴展和維護。記住不要在控制器中編寫所有業(yè)務(wù)邏輯。
每一層都有自己的分工,是捏合在一起的。代碼不僅冗長,而且雜亂無章。
好吧,我希望我的回答能幫助你
!如果你有興趣,可以關(guān)注一下,一起學(xué)習(xí)交流!