這篇文章主要介紹“如何簡(jiǎn)化數(shù)據(jù)庫操作”,在日常操作中,相信很多人在如何簡(jiǎn)化數(shù)據(jù)庫操作問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”如何簡(jiǎn)化數(shù)據(jù)庫操作”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!
創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供廬江網(wǎng)站建設(shè)、廬江做網(wǎng)站、廬江網(wǎng)站設(shè)計(jì)、廬江網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計(jì)與制作、廬江企業(yè)網(wǎng)站模板建站服務(wù),十余年廬江做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
我們?cè)趯懘a的時(shí)候,什么東西讓我們最痛苦? 我想大部分人都會(huì)說是重復(fù)的工作,但是重復(fù)的工作又是指什么呢? 我想了想可能包含以下幾點(diǎn):
實(shí)體類
建sqlMapper.xml,或者其他框架的注解映射
建DAO去關(guān)聯(lián)sqlMapper.xml,或者用代碼去替代sql
Controller
所以我在想,如果可以不需要實(shí)體類,不需要sqlMapper.xml,不需要Controller就好了,這樣一來,如果需要開發(fā)一個(gè)后端功能,只需要寫Service就好了,而這一段幾乎是編程中最有樂趣的地方(僅限應(yīng)用層編程,底層研發(fā)的當(dāng)我沒說)
而Mars-java就是在這樣的一個(gè)思路下誕生的
只需要在Service的父接口上加上兩個(gè)注解,即可對(duì)外提供一個(gè)http接口,又或者可以重新創(chuàng)建一個(gè)interface+注解 去代替Controller
操作數(shù)據(jù)庫只需要一行注解,沒有sqlMapper.xml
如果你能夠接受無實(shí)體類編程的話,可以不創(chuàng)建實(shí)體類,而采用Map
如果我們需要寫一個(gè)登錄接口只需要這么幾步
@MarsDao public abstract class UserInfoDAO { // 可以返回Map也可以返回實(shí)體類 @MarsSelect(sql = "select * from `userinfo` where uname=#{uname} and passwd=#{passwd}") public abstract List
按照慣例來說,我們需要先寫一個(gè)interface,再寫一個(gè)實(shí)現(xiàn)類
Interface
public interface UserInfoService { UserInfo login(MapuserInfo); }
實(shí)現(xiàn)類
@MarsBean public interface UserInfoServiceImpl implements UserInfoService { public UserInfo login(MapuserInfo){ // 在這里面調(diào)用DAO } }
只需要在UserInfoService上加兩個(gè)注解即可
@MarsApi public interface UserInfoService { @MarsReference(beanName = "userInfoServiceImpl",refName = "login") UserInfo login(MapuserInfo); }
整個(gè)流程省掉了很多重復(fù)性的代碼,讓我們專注在Service這一層
到此,關(guān)于“如何簡(jiǎn)化數(shù)據(jù)庫操作”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!