javaweb連接不上數(shù)據(jù)庫 Java Web開發(fā)中,業(yè)務(wù)邏輯寫在SQL里好還是代碼里好呢?有什么建議嗎?
Java Web開發(fā)中,業(yè)務(wù)邏輯寫在SQL里好還是代碼里好呢?有什么建議嗎?目前,大多數(shù)研發(fā)團(tuán)隊(duì)都要求用代碼實(shí)現(xiàn)業(yè)務(wù)邏輯,SQL操作往往是最基本的操作。用SQL表示業(yè)務(wù)邏輯,即用存儲過程表示業(yè)務(wù)邏輯,
Java Web開發(fā)中,業(yè)務(wù)邏輯寫在SQL里好還是代碼里好呢?有什么建議嗎?
目前,大多數(shù)研發(fā)團(tuán)隊(duì)都要求用代碼實(shí)現(xiàn)業(yè)務(wù)邏輯,SQL操作往往是最基本的操作。用SQL表示業(yè)務(wù)邏輯,即用存儲過程表示業(yè)務(wù)邏輯,是一種傳統(tǒng)的開發(fā)方案。
在C/s時(shí)代,很多邏輯都是通過SQL來實(shí)現(xiàn)的,主要是因?yàn)闃I(yè)務(wù)規(guī)模和部署方式。在早期的C/s編程時(shí)代,它通常是在非分布式環(huán)境中開發(fā)的,在大多數(shù)情況下,它不需要考慮可移植性問題。這時(shí),使用SQL來完成業(yè)務(wù)邏輯就更方便了。
使用存儲過程來完成業(yè)務(wù)邏輯的最大優(yōu)點(diǎn)是性能會更好,但這也取決于業(yè)務(wù)的大小。如果業(yè)務(wù)規(guī)模過大,業(yè)績會更差。早期的數(shù)據(jù)存儲規(guī)模比較小,所以使用存儲過程比較方便。
當(dāng)前網(wǎng)絡(luò)發(fā)展已進(jìn)入大數(shù)據(jù)、云計(jì)算時(shí)代,業(yè)務(wù)類型和業(yè)務(wù)規(guī)模發(fā)生了巨大變化。特別是隨著NoSQL數(shù)據(jù)庫在大數(shù)據(jù)時(shí)代的廣泛應(yīng)用,使用SQL語句來完成業(yè)務(wù)邏輯的場景越來越少。而且,目前大多數(shù)程序都是分布式的,使用SQL存儲過程處理業(yè)務(wù)邏輯非常麻煩,會導(dǎo)致整個(gè)項(xiàng)目的可移植性和可讀性嚴(yán)重下降。
目前,在傳統(tǒng)企業(yè)的開發(fā)團(tuán)隊(duì)中,使用SQL來處理業(yè)務(wù)邏輯是相當(dāng)普遍的,因?yàn)閭鹘y(tǒng)企業(yè)的數(shù)據(jù)庫大多還是關(guān)系數(shù)據(jù)庫,沒有可移植性的要求。這種固定的場景開發(fā)可以使用SQL來處理業(yè)務(wù)邏輯。在將來,使用SQL處理業(yè)務(wù)邏輯時(shí)會出現(xiàn)一些應(yīng)用場景,因此有必要學(xué)習(xí)如何編寫存儲過程。